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The  goal  of  this  thesis  is  to  design  and  implement  a  Motorola  68020-based 
Educational  Computer  Board  (ECB),  including  the  Motorola  68881  coprocessor.  The 
ECB  has  two  conununication  channels,  one  for  an  extonal  I/O  device  and  the  other  for 
a  Macintosh  personal  computer.  A  stcved  program  can  be  installed  in  8K  bytes 
Programmable  Read  Only  Memory  (PROM)  to  initialize  the  ECB  and  to  handle 
communication,  as  well  as  to  perform  user  commands  via  a  Macintosh  personal 


computer. 

The  ECB  operates  at  a  clock  frequency  of  16  MHz.  It  includes  four  Static 
Random  Access  Memory  (SRAM)  chips  which  provide  a  storage  of  32K  bytes.  Two 
Programmable  Array  Logic  (PAL)  chips  generate  the  required  decoding,  enabling  and 
timing  signals.  No  special  I/O  chip  is  used  in  Macintosh  interface,  except  for  a  RS-232 
line  driver/level  changer,  as  the  communication  on  this  channel  is  intended  to  be  under 
software  control  in  order  to  keep  the  hardware  as  simple  as  possible.  The  channel  for 
an  external  device  has  not  been  implemented  and  tested,  but  all  the  required  pads  and 
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I.  INTRODUCTION 


Microprocessors  continue  to  be  an  integral  part  of  many  complex  digital  systems. 
Through  improvements  in  manufacturing  techniques,  they  have  become  more  powerful 
and  more  complex.  This  power  and  flexibility  is  accompanied  by  increased  complexity 
and  difficulty  in  hardware  and  software  design.  The  hardware  designer  must  consider 
more  control  and  data  signals.  Similarly  software  design  entails  more  detailed 
considerations.  The  complexity  of  a  microprocessor-based  system  also  increases  the 
difficulty  of  maintenance  and  troubleshooting.  The  operation  of  such  a  system  should 
be  throughly  understood  before  attempting  any  troubleshooting  actitm. 

The  manufacturers  of  microprocessors  have  introduced  new  products  so  often  that 
the  number  of  people  who  know  and  use  diese  products  is  somewhat  limited.  The  best 
way  of  learning  a  system  is  through  using  it.  This  idea  forms  the  basis  for  the  thesis 
presented  here.  Within  the  scope  of  the  thesis,  an  Educational  Computer  Board  (ECB) 
has  been  designed  and  implemented  to  be  used 

•  as  a  tool  for  teaching  a  state-of-the-art  microprocessor  and  coprocessor  design, 
and 

•  as  an  experimental,  test,  or  control  device  for  scientific  applications. 

In  the  design  of  ECB,  the  main  consideration  was  to  use  the  minimum  number  of 
external  components  to  achieve  simplicity,  low-cost  and  reliability. 

In  the  chapter  "An  overview  of  MC68020  and  MC6888 1",  the  basic  operaticHis  of 
main  processor  and  co-processor  are  reviewed.  The  chtq>ter  "Design  and  Implementation 
of  the  ECB"  discusses  several  design  alternatives  and  explains  why  a  particular  design 
has  been  selected.  The  chapter  "Hardware  verification"  includes  the  outputs  of  a  series 
tests  to  verify  the  operation  of  the  ECB.  A  comparison  is  made,  in  the  last  diapter 
"Conclusions",  between  the  ECB  developed  in  this  thesis  and  the  ECB  previously 
designed  by  Motorola  and  still  in  use  in  miaoprocessor-based  courses  at  the  Naval 
Postgraduate  School.  Also  suggested  future  improvements  are  given  in  this  last  chapter. 
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U.  AN  OVERVIEW  OF  MC68020  AND  MC68881 


This  chapter  introduces  the  architecture  and  features  of  the  MC68020  and  its 
associated  coprocessor  MC6888 1.  Also  given  is  a  brief  description  of  the  signals  and 
the  interface  between  two  processors.  Detailed  information  on  the  signal  descriptitm, 
timing  and  instruction  set  is  given  in  Appendix  A,  B  and  D. 

A.  MC68020  Architecture  and  Features 

Implemented  in  VLSI  technology,  the  MC68020  is  upwardly  compatible  with  its 
predecessors,  the  M68000  and  M68010.  That  is,  in  addition  to  the  new  instructions,  all 
the  instructions  that  run  on  the  old  M68000  family  members,  can  be  run  on  MC68020. 
All  I/O  devices  that  can  be  connected  to  the  M68000  and  M68010  can  also  be 
connected  to  MC68020.  A  table  of  MC68020  instructions  and  new  instructions  which 
are  extensions  to  old  M68000  family  members  are  given  in  Appendix  D. 

The  MC68020  has  an  128  word  on-chip  cache  memory  (compared  to  3-word 
cache  memory  in  M68010  and  no  cache  memory  in  M68(X)0).  The  advantage  of  cache 
memory  is  to  reduce  both  the  total  execution  time  of  a  program  and  the  external  bus 
activity  of  the  processor  without  degrading  the  performance.  The  basic  idea  is  to  store 
the  instruction  stream  prefetched  from  main  memory  into  the  faster  on-chip  cache 
memory  so  that  the  processor  does  not  have  to  access  main  memory  to  fetch  the  next 
instruction  in  most  cases.  This  on-chip  cache  memory  can  be  enabled  or  disabled  by 
applying  an  external  signal  to  the  chip.  Hie  ECB  has  been  implemented  with  this 
feature  disabled. 

The  MC68020  contains  32-bit  data/address  registers  and  32-bit  data/address  buses. 
Thus,  it  can  directly  address  a  memory  range  of  4  Gigabytes.  In  each  bus  cycle,  the 
microprocessor  can  determine  the  port  size  of  the  external  device  to  or  from  which  an 
operand  is  to  be  transferred.  This  feature  is  called  "Dynamic  bus  sizing".  Ttie  MC68020 
can  be  connected  to  external  devices  having  port  sizes  of  8,  16  or  32-bits,  so  all  data 
alignment  restrictions  are  eliminated.  On  the  ECB,  32K  byte  ROM  is  connected  as  an 
8-bit  port  and  32K  byte  RAM  is  connected  as  a  32-bit  port.  An  input  signal  can  inform 
the  microprocessor,  if  an  external  device  does  not  respond  to  a  command  within  a 
specified  period  of  time,  so  that  the  microprocessor  can  initiate  a  new  bus  cycle.  This 


2 


signal  (BERR)  which  is  to  be  generated  by  an  external  circuit  has  not  been  used  on  the 
ECB,  as  the  purpose  in  the  design  is  to  use  minimum  hardware  to  the  degree  that 
guarantees  the  proper  operation  of  the  ECB,  as  well  as  to  make  it  easy  for  the 
programmer  to  write  the  software  that  will  handle  the  operation  of  the  ECB,  during  this 
development  phase.  Appendix  C  includes  the  information  on  "Bus  Operation"  and 
focuses  on  dynamic  bus  sizing  and  multiplexing  of  the  data  onto  the  external  bus. 

The  MC68020  has  three  processing  states,  and  it  is  always  in  one  of  these  states: 
normal,  exception  and  halt.  In  the  normal  state,  die  processor  executes  instructions 
(fetching  instructions  and  operands,  storing  results  and  communicating  with  the 
co-processor).  If  an  unusual  condition  (exception)  occurs  during  normal  instruction 
execution,  the  processor  enters  the  exception  state  to  handle  this  condition  easily.  An 
exception  can  be  generated  internally  by  an  instruction  or  externally  by  an  interrupt, 
reset,  etc.  The  processor  enters  the  halt  state  whenever  it  detects  a  system  failure.  In 
halt  state,  there  wUl  be  no  processor  activity,  until  an  external  reset  (the  only  means  to 
regain  the  processor  activity)  is  applied  to  restart  the  processor.  The  halt  state  is  not  the 
same  state  as  the  stopped  state  which  is  caused  by  STOP  instruction.  The  instruction 
execution  on  a  stopped  processor  resumes  after  a  trace,  interrupt  or  reset  exception. 

Within  each  of  the  three  processing  states,  there  are  two  privilege  levels,  user  and 
supervisor.  The  supervisor  state  has  higher  privilege  than  the  user  state,  so  that  all 
processor  instructions  are  available  to  execute  in  this  state.  In  the  user  state,  programs 
are  allowed  to  access  only  their  code  and  data  areas,  and  they  cannot  execute  some 
processor  instructions  related  to  system  functions.  This  provides  security  in  the 
microprocessor  system. 

The  MC68020  behaves  slightly  differently  in  the  supervisor  state  than  the  old 
M68000  family  members.  It  allows  the  separation  of  supervisor  stack  space  for  user 
tasks  and  for  interrupt  associated  tasks  in  order  to  increase  the  efficiency  in  a 
multi-tasking  operaing  system.  This  separation  is  enabled  by  setting  the  M  bit  in  the 
status  register.  The  M  bit  is  cleared,  whenever  an  exception  occurs  for  intorupts.  The 
processor  can  be  switched  from  the  user  state  to  the  supervisor  state  only  through 
exception  processing.  Switching  firom  the  supervisor  state  to  the  user  state  is 
accomplished  by  executing  an  instruction  that  can  modify  the  status  register.  Figure  1 
shows  the  positions  of  the  status  and  control  bits  in  the  status  register. 
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Figure  1  Status  Register 


The  MC68020  has  three  defined  types  of  address  space,  encoded  b>’  the  function 
code  pins  FC0-FC2.  These  address  spaces  are  the  user  data^rogram  space,  the 
supervisor  data/program  space  and  the  CPU  space,  as  shown  in  Table  1. 


Table  1  MC68020  Address  Spaces. 
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CPU  space 

The  user  and  supervisor  address  spaces  have  no  predefined  memory  locations, 
except  for  the  addresses  of  the  initial  interrupt  stack  pointer  and  program  counter  values 
that  are  held  in  the  first  two  longwords  of  the  supervisor  program  space.  The  MC68020 
fetches  these  two  longwords  and  loads  them  into  the  interrupt  stack  pointer  and  the 
program  counter,  respectively,  by  reading  from  supervisor  program  space.  CPU  space 
accesses  are  made  when  the  processor  cotnmunicates  with  the  external  devices  for  data 
movements  other  than  those  associated  with  instructions,  like  interrupt 
acknowledgements  and  coprocessor  operation.  During  CPU  space  accesses,  address 
lines  A19  through  A16  specify  the  type  of  CPU  space,  as  shown  in  Figure  2. 
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Figure  2  CPU  Space  Encoding 


On  the  ECB,  the  address  lines  A18,  A17  and  AIS  are  used  to  generate  the  chip 
enable  signal  for  the  MC6888 1  coprocessor.  The  function  code  lines  FC0-FC2  are  not 
incorporated  in  the  co-processor  chip  select  generation  circuit. 

In  the  processing  of  an  exception,  the  MC68020  goes  through  four  identifiable 

steps. 

1 .  An  internal  copy  of  the  status  register  is  saved  temporarily  and  the  status  register 
is  set  to  process  the  exception. 

2.  The  exception  vector  is  generated.  An  exception  vector  is  a  pointer  to  the 
memory  location  containing  the  address  of  the  routine  which  handles  the  specified 
exception.  There  are  254  exception  vectors  available  in  the  supervisor  data  space,  and  2 
vectors  for  the  reset  exception  in  supervisor  program  space.  A  group  of  64  vectors  is 
defined  by  the  processor  and  the  remaining  192  vectors  are  left  for  user  to  define. 
Exception  vectors  can  be  generated  externally  or  internally.  On  the  ECB,  all  the 
interrupts  are  auto-vectored,  that  is,  the  exception  vectors  are  generated  internally  by 
the  processor  upon  the  recognition  of  the  interrupt. 

3.  The  current  processor  context  is  saved  on  die  exception  stack  firame  created  on  the 
active  supervisor  stack.  This  context  always  includes  the  status  register,  the  program 
counter  and  the  vector  offset  for  the  exception  vector.  Another  field  on  the  exception 
stack  firame  called  "format  field"  is  used  to  specify  what  additional  processor  state 
information  has  been  put  onto  the  stack  frame,  as  there  is  more  than  one  type  of 
exception  stack  frame  created  by  different  exceptions. 

4.  At  the  last  step,  the  address  of  the  exception  handler  is  loaded  into  the  program 
counter,  then  the  instruction  at  that  address  is  fetched  and  the  program  execution  is 
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resximed. 


For  detailed  explanation  on  exception  processing,  see  Appendix  D. 

B.  MC68881  Architecture  and  Features 

The  MC6888 1  floating-point  coprocessor  is  implemented  in  VLSI  and  HCMOS 
technology  which  combines  the  HMOS  (Hi^  Density  NMOS)  and  CMOS 
technologies  to  achieve  low  power,  high  speed  and  minimum  silicon  area.  Aldiough  it 
is  primarily  designed  for  use  with  MC68020  microprocessor,  it  can  also  be  used  with 
the  old  M68000  family  members  with  some  degradation  in  the  performance.  This  is 
due  to  the  fact  that  the  MC6888 1  is  recognized  as  a  coprocessor  by  die  MC68020  and 
as  a  peripheral  processor  by  die  other  M68000  family  members.  The  data  bus  on 
which  MC68881  operates  can  be  8,  16  or  32-bits  wide.  The  MC68881  has  eight  16-bit 
and  four  32-bit  co-processor  Interface  Registers  (QR)  which  are  memory-mapped  to 
the  CPU  address  space  of  MC68020  in  order  to  provide  exchange  of  commands  and 
data. 

From  the  programmer’s  point  of  view,  the  pair  MC68020/MC68881  can  be 
thought  as  one  MC68020  processor  implemented  on  the  same  chip,  having  additional 
eight  floating-point  data  registers.  Each  floating-point  data  register  is  80-bit  wide  (1 
sign  bit,  64  bits  for  mantissa  and  IS  bits  for  exponent).  The  MC6888 1  fully  conforms 
to  IEEE  P7S4  Binary  Floating  Point  Arithmetic  Standard  and  supports  seven  data  types: 
byte,  word,  long  integer,  single,  double,  extended  precision  real  and  packed  BCD  real. 
There  are  22  scientific  constants  available  on  the  chip. 

Appendix  E  includes  detailed  information  on  the  MC6888 1  registers  and  data 
types.  Appendix  B  contains  the  MC6888 1  signal  description. 

C.  The  Interface  Between  the  MC68020  and  MC68881 

The  interface  between  the  MC6888 1  and  die  main  process^  is  provided  by  the 
M68000  Family  coprocessor  interface  which  allows  ccxmection  of  up  to  eight 
co-processors.  Each  co-processor  is  addressed  by  driving  its  ID  number  on  the  address 
lines  A13  through  A15.  On  the  ECB,  these  lines  are  not  decoded  to  generate  the  chip 
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select  signal,  as  there  is  only  one  co-processor  which  is  always  addresssed  for  any  ID 
number. 

The  main  processor  MC68020  communicates  with  the  floating  point  coprocessor 
MC6888 1  over  a  32-bit  data  bus,  and  accesses  the  coprocessor  intoface  registers 
through  bus  cycles.  Each  interface  register  (CIR)  has  a  specific  function  and  is  used  as 
a  communication  port.  The  coprocessor  connection  diagram  for  32-bit  data  bus  is  givoi 
in  Appendix  F.  On  die  ECB,  function  codes  FC0-FC2  are  not  used  for  the  generation 
of  chip  select  signal. 

The  interface  tasks  are  divided  between  the  MC68020  and  MC6888 1  so  tiiat  they 
do  not  duplicate  each  other’s  functions.  For  example,  the  main  processor  does  not  have 
to  decode  the  co-processor  instructions;  it  is  the  responsibility  of  the  co-processor  to 
decode  these  instructions.  On  the  other  hand,  the  coprocessor  does  not  involve  the 
calculation  of  the  effective  address.  It  only  instructs  the  main  processor  to  transfer  an 
operand  over  the  interface,  then  it  is  the  responsibility  of  the  main  processor  to 
calculate  the  effective  address  and  fetch  the  operand.  Thus,  the  coprocessor  never 
becomes  a  bus  master. 
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m.  DESIGN  AND  IMPLEMENTATION  OF  THE  ECB 


This  chapter  gives  a  brief  description  of  how  the  ECB  has  been  amfigured  and 
discusses  the  design  of  the  external  hardware,  as  well  as  the  benefits  of  the  particular 
design  selected.  The  description  of  external  circuits  are  not  given  in  detail  in  this 
chapter.  Appendix  G  can  be  referred  to  for  detailed  information. 

A.  Introduction  to  the  Design 

Before  going  into  the  details  of  the  design,  the  configuration  of  the  ECB  had  to 
be  determined,  that  is,  what  external  devices  would  be  connected  to  the  main  processor 
and  in  which  way  they  would  be  connected.  The  ECB  was  intended  to  communicate 
with  a  smart  terminal  to  download  user  programs  and  to  issue  commands  for  running 
the  downloaded  programs  and  for  manipulating  the  other  ECB  fimctions.  Thus,  the  first 
external  device  was  a  smart  terminal,  like  a  personal  computer.  Memory  was  the 
second  external  device  to  exist  on  the  ECB,  since  every  processor  needs  some  memory 
for  storing  programs  and  data.  The  last  external  device  was  the  MC6888 1  coprocessor. 

Once  the  configuration  of  the  ECB  had  been  determined,  the  next  step  was  to 
design  the  external  circuits  which  would  provide  the  required  interface  between  the 
MC68020  and  the  three  external  devices.  The  main  objective  in  the  design  of  the 
external  circuits  was  to  keep  the  hardware  at  the  required  minimum  to  allow  proper 
operation  of  the  ECB  in  the  simplest  and  primitive  way. 

All  handshake  signals  for  three  external  devices  are  generated  by  two 
Programmable  Array  Logic  IC’s  PAL16R4  and  PAL16L8.  Another  integrated  circuit, 
MAX232  converts  the  RS-232  line  voltage  levels  to  TTL-voltage  levels  and  vice  versa, 
with  a  +5V  power  supply  only.  Except  for  the  reset  and  software  abort  circuits,  the 
other  main  components  on  the  ECB  are  the  MC68020  prcicessor,  the  MC6888 1 
cqprocessor  and  the  memory  chips  (1  27C256  ROM  chip,  4  6164  RAM  chips). 

In  the  following  sections  the  interface  with  each  external  device  will  be  discussed 
separately. 
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B.  Interfacing  with  the  Memory 


The  memory  to  be  implemented  should  be  large  enough  to  hold  the  initialization 
and  user  programs/data,  as  well  as  the  basic  routines,  but  small  enou^  to  keq>  the 
hardware  simple  and  inexpensive.  Small  monory  size  also  allows  the  high  order 
address  bits  to  be  used  for  other  purposes,  like  RS-232  transmissitm  and  receptitm,  as 
explained  later. 

1.  Non-voladle  memory  (ROM)  is  used  to  hold  the  initialization  data  and  routine 
during  power-up.  An  8K  byte  ROM  is  sufficient  for  that  purpose. 

2.  Volatile  memory  (RAM)  is  required  to  hold  the  user  programs  and  data  to  be 
downloaded  via  the  RS-232  interface.  A  32K  byte  RAM  was  found  to  be 
satisfactory  for  this. 

An  important  design  consideration  is  what  kind  of  information  is  to  be  stored  in 
non-volatile  and  volatile  memories.  It  was  decided  that  low  level  routines  for 
initialization,  I/O  (input/output)  and  exception  handlers  would  be  kept  in  ROM  in  order 
to  provide  security  for  basic  routines  which  should  not  be  destroyed  by  overwriting.  A 
requirement  imposed  by  the  system  is  that  ROM  must  be  accessed  in  the  very  first 
addresses  to  allow  for  fetching  the  initial  interrupt  stack  pointer  and  program  counter 
values  (reset  exception  vector).  On  the  other  hand,  it  is  very  convenient  for  the  user  to 
write  his/her  own  exception  routines  and  to  change  the  contents  of  the  exception  vector 
table  located  in  low  memory.  This  stipulates  diat  bodi  ROM  and  RAM  must  be 
mapped  into  low  addresses  which  is  the  case  with  the  current  implementation  during 
power-up  or  reset.  In  order  to  prevent  coUisiem  on  the  data  bus,  aU  reads  are  made 
firom  the  ROM  and  all  writes  go  to  RAM  when  both  memories  are  mapped  into  the 
same  space.  This  allows  both  to  fetch  the  reset  exception  vector  and  to  copy  the 
contents  of  ROM  to  RAM.  After  a  copy  of  ROM  is  made  to  RAM,  then  the  ROM  is 
detached  from  the  low  addresses  and  mapped  into  higher  addresses.  Only  RAM  is 
accessible  for  reading  and  writing  in  the  low  addresses  thereafter.  By  this  scheme,  the 
user  can  change  the  excq)tion  vectors  in  low  memory  RAM  and  can  access  the  basic 
routines  in  high  memory  ROM. 
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The  last  step  in  the  design  process  was  the  development  of  the  external  circuits  in 
order  to  generate  the  required  int^ace  signals  with  proper  timing.  These  signals  are 
generated  by  two  PAL  (Programmable  Array  Logic)  circuits.  PAL  A  (PAL16R4) 
generates  the  signal  (PHANTOM)  which  detaches  ROM  from  low  addresses  and  miq}s 
into  higher  addresses.  PAL  A  also  returns  "Data  size  and  acknowledge"  signals 
(DSACKO,  DSACKl)  which  tells  MC68020  that  an  8-bit  port  (or  32-bit  port)  has  been 
accessed  when  ROM  (or  RAM)  was  addressed.  PAL  B  (PAL16L8)  generates  the  chip 
select  signals  for  both  ROM  and  RAM,  and  Read/Write  signal  for  RAM,  thus 
performing  the  memory  mapping.  DSACK  signals  for  ROM  accesses  are  delayed  to 
make  sure  that  correct  data  has  been  put  on  the  data  bus,  since  the  ROM  chip  has  a 
longer  access  time  than  the  RAM  chips.  The  volatile  memory  has  been  chosen  for 
static  RAM  (SRAM)  which  eliminates  the  refresh  hardware  required  for  IDynamic 
RAMs  and  provides  faster  access  time. 

As  a  summary  of  memray  interfacing:  the  size  of  the  memory  (8K  byte  ROM 
and  32K  byte  RAM)  is  sufficient  for  most  programs  and  leaves  high  order  address  bits 
to  be  used  for  other  purposes.  Static  RAM  helps  the  designer  reduce  the  hardware.  It 
also  provides  fast  access  and  reliability.  The  memory  mapping  scheme  imposes  access 
of  ROM  in  low  addresses,  during  power-up  or  reset,  and  in  high  addresses  after 
initialization,  in  order  to  execute  the  basic  routines.  This  technique  enables  the  user  to 
modify  the  system  data  located  in  RAM  in  the  low  address  region.  Appendix  G  covers 
more  detailed  information  on  memory  interfacing. 


C.  Interfacing  with  a  Smart  Terminal 

The  ECB  communicates  with  a  smart  terminal  via  a  serial  RS-232  interface.  The 
serial  interface  is  simple;  it  requires  only  three  wires,  but  it  is  slower  when  compared 
to  a  parallel  interface  with  the  same  clock  rate.  A  voltage  level  converter  chip  matches 
the  signal  levels  on  the  ECB  to  the  RS-232  tne.  No  special  I/O  (input/output)  chip  has 
been  used.  The  reception  and  transmission  on  the  RS-232  interface  has  been 
implemented  in  software  to  keep  the  hardware  simple  (see  Reference  1).  Input  and 
output  signals  for  RS-232  are  passed  through  PAL  A  and  buffered  by  the  level 
converter  chip.  Setting  the  address  lines  A19  and  A15  to  high  causes  a  zero  to  be 
transmitted  on  the  RS-232  line.  On  the  other  hand,  setting  the  address  lines  A19  and 
A17  to  high  causes  the  RS-232  line  to  be  strobed.  If  the  line  is  found  high  (a  zero  bit) 
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then  an  autovectored  interrupt  of  level  4  is  generated.  The  reception  of  the  incoming 
byte  can  be  handled  by  the  interrupt  handler  pointed  by  level  four  interrupt  vector 
entry.  With  this  scheme,  the  conununication  with  a  smart  terminal  is  only  possible 
when  RS-232  line  is  monitOTed  by  the  software  on  the  ECB.  For  detailed  explanation 
and  circuit  diagrams  of  this  interface  see  Appendix  G,  H,  and  I. 

D.  Interfacing  with  MC68881  Coprocessor 

The  most  efficient  and  fastest  interface  between  the  MC68020  and  its  dedicated 
coprocessor  MC6888 1  is  via  a  32-bit  data  bus.  Both  processors  use  the  same  clock, 
although  they  can  run  on  different  clocks.  The  connection  of  most  signals  are 
straightforward  and  direct.  The  only  signal  to  be  dealt  with  here  is  the  chip  select 
(CopE)  which  is  generated  by  PAL  B  out  of  the  address  lines  A18,  A17  and  A15.  The 
chip  select  signal  for  the  coprocessor  is  also  used  in  the  generation  of  anothn^  signal 
(PHANTOM)  which  detaches  ROM  from  low  address  region  after  initialization. 
Appendix  G,  H  and  I  include  the  detailed  explanation  of  the  interface  and  the 
generation  of  the  chip  select  signal. 

E.  Reset  and  Software  Abort  Circuits 

The  main  processor  and  the  coprocessor  must  be  reset  in  order  to  set  their  states 
and  registers  to  predefined  and  known  values.  This  arises  in  two  cases^  initial  power-up 
and  reset  after  a  catastrophic  system  failure  in  order  to  bring  the  system  up.  It  is 
guaranteed  that  both  processors  recognize  the  reset  condition  if  their  reset  inputs  are 
held  low  at  least  100  ms  by  the  external  circuit.  The  reset  circuit  which  has  been  built 
around  Motorola’s  low  voltage  detector  is  quite  simple.  An  external  resistor-capacitor 
combination  provides  the  required  delay  of  at  least  100  ms. 

In  case  the  user  program  runs  out  of  control  or  enters  an  unintended  loop  for  any 
reason,  the  user  must  have  a  means  to  abort  the  program  and  remm  to  a  defrned  point 
before  re-running  the  program  without  resetting  the  processor.  This  is  provided  by  the 
software  abort  circuit  consisting  of  all  passive  components.  The  circuit  generates  an 
autovectored  interrupt  of  level  6,  upon  pushing  the  software  abort  button.  The  level  of 
the  interrupt  is  one  less  than  the  non-maskable  highest  level.  The  reason  for  choosing  a 
level  6  interrupt  rather  than  a  level  seven  interrupt  is  that  the  output  of  the  abort  circuit 
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is  not  debounced.  This  causes  more  than  one  interrupt  to  occur  sequentially,  after  the 
software  abort  switch  is  released.  If  a  level  seven  interrupt  is  generated  by  the  software 
abort  circuit,  all  the  successive  interrupts  (non-maskable)  due  to  non-debounced  ouq}ut 
will  be  recognized.  This  imposes  a  delay  in  the  processing  of  die  interrupt,  and 
unnecessary  pushes  onto  the  stack,  until  the  bouncing  of  the  switch  stqis.  Assigning  a 
level  6  interrupt  to  the  software  abort  function  improves  the  response  considerably.  In 
the  interrupt  handler  for  the  software  abort,  die  mask  level  in  the  status  register  is  set 
to  7,  before  beginning  the  exception  processing  so  that  further  level  6  interrupts  are  not 
recognized  (sec  Reference  1).  This  greatly  reduces  the  number  of  spurious  level  6 
interrupts  that  are  recognized  after  the  first  one. 
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IV.  HARDWARE  VERIFICATION 


After  implementation,  the  hardware  has  been  verified  by  running  a  series  of  short 
routines  to  test  the  following: 

•  ROM  read. 

•  Generation  of  the  coprocessor  chip  enable  CopE  and  PHANTOM  signals. 

•  RAM  read/write. 

•  Coprocessor  conununication. 

•  Interrupt  4  (RS-232  recq)tion)  operation. 

•  Interrupt  6  (Software  Abort)  operation. 

All  the  tests  have  been  conducted  by  using  the  debugger  in  Reference  1  and  the  Logic 
Analyzer  HP1650A. 

A.  ROM  Read  Test. 

The  routine  for  the  ROM  read  test  is  the  RS232  reception  routine,  itself,  which 
resides  in  the  ROM  (See  Reference  1).  A  part  of  the  state  listing  for  tiiis  routine  is 
given  in  Figure  3,  in  which  the  MC68020  makes  sequential  reads  from  supervisor 
program  space.  DSACK  signals  generated  by  the  PAL  B  return  an  8-bit  port  size  for 
the  ROM.  The  timing  waveforms  are  shown  in  Figure  4,  where  it  can  easily  be  seen 
that  function  codes  (FC2  through  FCO)  are  encoded  for  supervisor  program  address 
space.  IDSACKl  signal  stays  high  all  the  time  and  only  IDASCKO  is  asserted,  after 
IDS  and  !AS  are  asserted,  to  indicate  an  8-bit  port  size.  The  ROM  chip  enable  signal 
ROMCE  is  the  only  chip  select  signal  that  is  active.  Figure  6  shows  the  relation 
between  IDSACKO  and  IAS.  IDS  in  an  expanded  scale.  The  X  marker  is  at  the  point 
where  IAS  and  IDS  are  asserted,  and  the  O  marker  is  at  the  point  where  IDSACKO  is 
asserted.  The  specification  for  the  time  between  two  markers  is  80  ns  maximum  (See 
Appendix  A  ).  The  measured  time  is  70  ns  as  seen  in  Figure  5. 
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68020 


State  Listing 

o7r  I 


Markers  [ 


Label  > 

ADDR 

DATA 

STAT 

DSACK 

Base  > 

Hex 

Hex 

Sumbol 

Symbol 

+0000 

000404DA 

4EOOOOOO 

SUPR 

PGRH 

READ 

0 

BIT 

PORT 

+0001 

000404DB 

F9000000 

SUPR 

PGRM 

READ 

8 

BIT 

PORT 

+0002 

000404DC 

00000000 

SUPR 

PGRtI 

READ 

8 

BIT 

PORT 

+0003 

000404DD 

OEOOOOOO 

SUPR 

PGRM 

READ 

8 

BIT 

PORT 

+0004 

000404DE 

04000000 

SUPR 

PGRM 

READ 

8 

BIT 

PORT 

+0005 

000404DF 

EOOOOOOO 

SUPR 

PGRM 

READ 

8 

BIT 

PORT 

+0006 

OOOE04EO 

4EOOOOOO 

SUPR 

PGRM 

READ 

6 

BIT 

PORT 

1+00071 

000E04E1 

71000000 

SUPR 

PGRM 

READ 

6 

BIT 

PORT 

+0008 

000E04E2 

4EOOOOOO 

SUPR 

PGRM 

READ 

8 

BIT 

PORT 

+0009 

000E04E3 

71000000 

SUPR 

PGRM 

READ 

8 

BIT 

PORT 

+0010 

000E04E4 

4EOOOOOO 

SUPR 

PGRM 

READ 

8 

BIT 

PORT 

+0011 

000E04E5 

71000000 

SUPR 

PGRM 

READ 

8 

BIT 

PORT 

+0012 

000E04E6 

4E000000 

SUPR 

PGRM 

READ 

8 

BIT 

PORT 

+0013 

000E04E7 

F9000000 

SUPR 

PGRM 

READ 

8 

BIT 

PORT 

+0014 

000E04E8 

00000000 

SUPR 

PGRM 

READ 

8 

BIT 

PORT 

Figure  3  State  listing  for  the  ROM  read  test 


Figure  4  Timing  waveforms  for  the  ROM  read  test 


14 


68020 


-  Timing  Haver orms 


Markers 


Time 


Accumulate 
Tlme/Dlv 


100  ns 


X  to  Trig  I  10.73  us  I  I  Time  X  to  0 
I  Trig 
Delay 


70  ns 


Off  I  0  to  Trig  I  10.80  uTl  At  I  X  Markerl 

0 


ROMCE 


10.74  us 


+ — 

hMHnI! 

_ 

FCQ  Oil 

-off- 

.  - 

- 1 

nc  All 

— 1 

li 

J - 

Figure  5  Timing  between  IDSACKO  and  !AS,  IDS 


B.  Testing  the  Coprocessor  Enable  (CopE)  and  Phantom  signals. 

The  test  routine  for  these  two  signals  is  the  initialization  routine  for  the  ECB 
(See  Reference  1).  The  state  listing  for  part  of  the  routine  is  shown  in  Figure  6.  When 
the  PHANTOM  signal  is  high  (default  state  after  a  reset  or  power  up),  an  image  of  the 
ROM  is  mapped  onto  the  RAM,  and  all  reads  are  made  from  ROM,  whereas  all  writes 
go  to  the  RAM.  After  the  PHANTOM  is  driven  low,  the  ROM  image  is  removed  from 
RAM  region  and  the  RAM  can  be  accessed  for  both  reading  and  writing.  The  only  way 
to  drive  the  PHANTOM  low  is  to  make  a  coprocessor  access.  In  the  initialization 
routine,  the  coprocessor  is  accessed  by  MOVEX  instruction  to  read  data  from  $2(X)00, 
which  is  shown  as  supervisor  data  space  in  Rgure  6  (lines  +00(X)  and  +0001). 
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68020  1-  Stale  Listing  (  Invasm  ) 


Markers 


Off 


Label  > 

f^DDR 

1  68020  Mnemonic  II 

Base  > 

Hex 

Ideclmal  (t  • 

hex) 

.  ir^ 

+0000 

00020000 

•0802XXXX 

supr  data 

read 

SUP 

+000) 

00020002 

•FFFFxxxx 

supr  data 

read 

SUP 

+0002 

00000434 

CHK2.L 

(A2).D0  - 

SUP 

+0003 

000404DO 

RTS 

SUP 

+0004 

000404D1 

•75XXXXXX 

supr  prom 

read 

SUP 

+0005 

000404D2 

MOVEM.L 

rm-tEF00.-(A7) 

SUP 

+0006 

000404D3 

•E7XXXXXX 

supr  prgm 

read 

SUP 

1+0007 

0001FFF6 

•00000436 

supr  data 

write 

SUP 

+0008 

000404D4 

•EFxxxxxx 

supr  prgm 

read 

SUP 

+0009 

000404D5 

tOOxxxxxx 

supr  prgm 

read 

SUP 

+0010 

000404D6 

MOVE. 8 

e«01 ,D1 

SUP 

+001  I 

000404D7 

•3CXXXXXX 

supr  prgm 

read 

SUP 

+0012 

00040408 

•OOxxxxxx 

supr  prgm 

read 

SUP 

+0013 

000404D9 

tOl  xxxxxx 

supr  prgm 

read 

SUP 

+0014 

000404Dft 

JMP 

t000E04E0 

SUP 

Figure  6  State  listing  of  the  routine  for  CopE  and  Phantom  tests. 


Figure  7  Timing  waveforms  for  CopE  and  Phantom  signals. 
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Figure  7  shows  the  timing  diagram  for  CopE  and  PHANTOM  signals.  The 
PHANTOM  signal  goes  low  110  ns  after  the  CopE  signal  is  asserted,  and  it  is  not 
affected  by  the  negation  of  CopE.  The  first  read  (deration  after  die  negation  of  CopE 
is  made  from  RAM,  which  is  only  possible  when  the  PHANTOM  is  low.  (See  line 
+(X)02  in  Figure  7  and  the  point  where  both  DSACK  signals  are  driven  low 
simultaneously,  to  indicate  32  bit  RAM  port,  in  Figure  7). 


C.  RAM  Read/Write  Test 


The  routine  for  this  test  was  downloaded  by  using  the  debugger  in  Reference  1. 
Figure  8  shows  the  piece  of  the  code. 


00001000 

21FC55555555<5000M(X>E.L 

«H31655745,«00004000 

00001008 

20384000 

MOOE.L 

«0000(S000,D0 

OOOOIOOC 

4000FFF2 

BRA.L 

$001000 

Figure  8  Test  routine  for  RAM  read/write  test 


The  state  listing  for  this  routine  is  given  in  Figure  9.  A  32-bit  port  size  is 
indicated  by  the  DSACK  signals.  The  routine  runs  in  the  supervisor  state  and  repeats 
itself  with  the  sequence:  three  sequential  program  reads  (lines  +0004  through  +0006), 
one  data  write  (line  +0007),  one  program  and  data  read  (lines  +0008  and  +0009),  and 
another  program  read  (line  +0010).  This  sequence  can  also  be  seen  in  the  timing 
diagram  given  in  Figure  10.  The  X  cursor  line  corresponds  to  the  line  +0000 
(SUPERVISOR  DATA  WRITE)  in  Figure  10.  Function  Code  signals,  FC2  through 
FCO,  either  indicate  supervisor  data  space  (101)  or  supervisor  program  space  (110). 
DSACK  signals  always  return  a  32-bit  port  size  and  only  the  RAM  chip  enable  signal 
RAMCE  is  active.  Figures  12  and  13  show  the  timing  between  the  negation  of  IAS, 
IDS  signals  and  the  negation  of  DSACK  signals  during  a  write  and  read  operation, 
respectively.  The  specification  for  this  period  is  80  ns  maximum  and  it  was  measured 
as  70  ns. 
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68020 


-  State  Listing 


Morkers 


Off 


Figure  9  State  listing  of  the  routine  for  RAM  read/write  test 


Label  > 
Base  > 

AOOR 

DATA 

STAT 

DSACK 

Hex 

Hex 

Sgmbol 

Sumbol 

+0000 

00006000 

55555555 

SUPR 

DATA 

HRITE 

32 

BIT 

PORT 

+0001 

0000 lOOC 

6000FFF2 

SUPR 

PGRtt 

READ 

32 

BIT 

PORT 

+0002 

00006000 

55555555 

SUPR 

DATA 

READ 

32 

BIT 

PORT 

+0003 

0000 1010 

0C4IF0A2 

SUPR 

PGRtt 

READ 

32 

BIT 

PORT 

+0004 

00001000 

21FC5555 

SUPR 

PGRtt 

READ 

32 

BIT 

PORT 

+0005 

00001004 

55556000 

SUPR 

PGRtt 

READ 

32 

BIT 

PORT 

+0006 

00001008 

20386000 

SUPR 

PGRtt 

READ 

32 

BIT 

PORT 

1+00071 

00006000 

55555555 

SUPR 

DATA 

HRITE 

32 

BIT 

PORT 

+0008 

0000 lOOC 

6000FFF2 

SUPR 

PGRtt 

READ 

32 

BIT 

PORT 

+0009 

00006000 

55555555 

SUPR 

DATA 

READ 

32 

BIT 

PORT 

+0010 

00001010 

0C41F0A2 

SUPR 

PGRtt 

READ 

32 

BIT 

PORT 

+0011 

00001000 

21FC5555 

SUPR 

PGRtt 

READ 

32 

BIT 

PORT 

+0012 

00001004 

55556000 

SUPR 

PGRtt 

READ 

32 

BIT 

PORT 

+0013 

00001008 

20386000 

SUPR 

PGRtt 

READ 

32 

BIT 

PORT 

+0014 

00006000 

55555555 

SUPR 

DATA 

HRITE 

32 

BIT 

PORT 

Figure  10  Timing  diagram  for  RAM  read/write  test. 
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Figure  11  Timing  waveforms  for  IAS,  IDS  and  IDSACK  during  write  operation. 


Figure  12  Timing  waveforms  for  IAS,  IDS  and  IDSACK  during  read  operation. 
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D.  Coprocessor  communication  test 

The  routine  for  this  test  consists  of  a  loop  of  the  instruction  FPMOVE  #7JFP7 
and  given  in  Figure  13.  The  state  listing  obtained  during  the  execution  of  this  routine  is 
given  in  Figure  14,  and  Figure  15  shows  the  corresponr^g  timing  waveforms. 


00001000 

F23C 

UORD 

♦F23C 

00001002 

4380 

CHK.U 

D0,D1 

00001004 

00000007 

OR.B 

*7,  DO 

00001008 

6000FFF(S 

BRA.L 

4001000 

OOOOIOOC 

6000FFF2 

BRA.L 

4001000 

Figure  13  Test  routine  for  coprocessor  communication 


68020 

STATE  LISTING 

Label  > 

ADDR 

DATA 

STAT 

1 

DSACK 

Base  > 

Hex 

Hex 

Symbol 

Symbol 

i-0000 

00022000 

0300FFF6 

CPU 

SPACE 

16 

BIT 

PORT 

+0001 

0000 I00C 

6000FFF2 

SUPR 

PGRM 

READ 

32 

BIT 

PORT 

+0002 

00001000 

F23C4380 

SUPR 

P6RI1 

READ 

32 

BIT 

PORT 

+0003 

00001004 

00000007 

SUPR 

PGRM 

READ 

32 

BIT 

PORT 

+0004 

0002200A 

43804380 

CPU 

SPACE 

16 

BIT 

PORT 

+0005 

00022000 

95044380 

CPU 

SPACE 

16 

BIT 

PORT 

+0006 

00022010 

00000007 

CPU 

SPACE 

32 

BIT 

PORT 

+0007 

0000 1 008 

6000FFFB 

SUPR 

PGRM 

READ 

32 

BIT 

PORT 

+0008 

00022000 

0900FFF6 

CPU 

SPACE 

16 

BIT 

PORT 

+0003 

0000 100C 

6000FFF2 

SUPR 

PGRM 

READ 

32 

BIT 

PORT 

+00 1 0 

0000 1 000 

F23C4380 

SUPR 

PGRM 

READ 

32 

BIT 

PORT 

+001 1 

00001004 

00000007 

SUPR 

PGRM 

READ 

32 

BIT 

PORT 

+0012 

0002200A 

43804380 

CPU 

SPACE 

16 

BIT 

PORT 

+0013 

00022000 

95044380 

CPU 

SPACE 

16 

BIT 

PORT 

+0014 

00022010 

00000007 

CPU 

SPACE 

32 

BIT 

PORT 

+0015 

00001008 

6000FFFB 

SUPR 

PGRM 

READ 

32 

BIT 

PORT 

Figure  l4  State  listing  for  the  routine  to  test  the  coprocessor  communication. 
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The  execution  of  the  instruction  begins  by  a  supervisor  program  read  from  the  address 
$1000  (lines  +0002  and  +0003  in  Figure  14).  Since  this  is  an  F-line  instruction,  the 
MC68020  writes  to  the  conunand  CIR,  which  has  an  offset  $0A  (line  +0004)  and  reads 
the  response  CIR  (line  +0005).  The  response  CIR  contains  the  primitive  "Evaluate 
Effective  Address  and  Transfer  Data"  (code  9504).  Then,  the  MC68020  writes  the 
immediate  data  into  the  operand  register  which  has  an  offset  $10  (line  +0006).  The 
next  read  from  the  response  CIR  returns  a  "Null  primitive"  (code  $0900)  which  shows 
that  the  MC68020  is  not  needed  for  the  execution  of  the  coprocessor  instruction,  so 
that  the  MC68020  can  continue  to  execute  the  next  instruction.  The  routine  loops  after 
executing  the  branch  instruction  (line  +0(X)7).  As  it  can  be  seen  both  in  the  state  listing 
and  the  timing  waveforms,  the  port  size  returned  during  coprocessor  accesses  depends 
on  the  length  of  the  CIR  register  being  addressed  by  the  MC68881.  A  16-bit  port  size 
is  returned  for  the  response  and  command  CIRs,  which  are  16-bit  wide  (lines  +0004 
and  +0005  in  Figure  14),  and  32-bit  port  size  is  returned  for  the  32-bit  wide  operand 
register  (line  +0006  in  Figure  14).  As  shown  in  Figure  15,  the  time  between  the 
assertion  of  coprocessor  chip  select  signal  CopE  and  the  assertion  of  IDS  signal  was 
measured  as  50  ns,  for  which  the  specification  is  35  ns  minimum. 


Figure  15  Timing  waveforms  for  the  coprocessor  communication  test 
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E.  Interrupt  Level  4  (RS232  communication)  test 


The  interrupt  routine  used  during  this  test  is  the  one  in  Reference  1.  The  state 
listing  and  the  timing  waveforms  are  giveiir  in  Figures  16  and  17,  respectively.  A  level 
4  interrupt  is  generated,  when  1IPL2  line  is  driven  low  (X  marker  position  in  Figure 
18).  The  MC68020  acknowledges  the  interrupt  by  setting  all  die  function  code  lines 
high  (O  marker  position  in  Figure  17).  During  this  interrupt  acknowledge  cycle,  the 
address  lines  A3  through  A1  contain  die  level  of  the  interrupt  being  acknowledged,  and 
all  the  other  address  lines  are  driven  hi^  (line  +0008  in  Figure  16).  Then,  a  four-word 
stack  frame  (Format  $0)  is  created  and  the  current  processor  context  is  saved  (Xito  this 
frame,  as  follows  (refer  to  the  line  numbers  in  Figure  16): 

•  line  +0009  :  save  the  status  register. 

(writing  a  word  (^rand  to  32  bit  port) 

•  line  +0011  and  +0012  :  save  the  program  counter. 

(This  is  also  an  example  of  writing  a  misaligned  longword  to 
32  bit  port.  Due  to  misalignment,  the  MC68020  makes  two 
successive  accesses  to  the  stack) 

•  line  +0017  :  save  the  format  number  and  vector  offset. 

(writing  a  word  operand  to  32  bit  port) 

The  address  of  the  interrupt  handler  ($00040C08)  is  fetched  from  the  exception  vector 
address  ($00000070)  for  the  level  4  interrupt  (line  +0010),  and  the  MC68020  enters  the 
interrupt  handler  routine  (line  +0013).  As  it  can  be  seen  in  the  state  listing,  because  of 
the  instruction  prefetch,  the  order  of  the  processor  activity  does  not  show  the  actual 
order  of  the  instructions  executed.  For  example,  the  last  program  read,  before  the 
interrupt  acknowledge  is  from  the  address  $(X)0E04E7  (line  +(X)07),  but  the  PC  value 
saved  on  the  stack  frame  is  $000E04E2  (lines  +0011  and  +(X)12).  This  indicates  that 
the  MC68020  did  not  execute  the  instructions  stored  in  memory  locatimis  $000E04E2 
and  higher,  thus  the  instructions  fetched  in  die  Unes  +0003  through  +0007  are  only 
prefetched  instructions  which  were  not  executed  yet. 
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60020 


-  State  Listing 


Markers 


Off 


Figure  16  State  listing  for  the  interrupt  level  4 


Label  > 

ADDR 

DATA 

STAT 

1  DSACK 

Base  > 

Hex 

Hex 

Symbol 

+0003 

000E04E3 

71000000 

SUPR  PGRM  READ 

8  BIT  PORT 

+0004 

000E04E4 

4E000000 

SUPR  PGRM  READ 

B  BIT  PORT 

+0005 

000E04E5 

71000000 

SUPR  PGRM  READ 

8  BIT  PORT 

+0006 

000E04E6 

4E000000 

SUPR  .PGRM  READ 

B  BIT  PORT 

■r0007 

000E04E7 

F9000000 

SUPR  PGRM  READ 

8  BIT  PORT 

+0008 

FFFFFFF9 

00000000 

CPU  SPACE 

HAIT  STATE 

+0009 

0001BD54 

20002000 

SUPR  DATA  HRITE 

32  BIT  PORT 

+0010 

00000070 

00040C08 

SUPR  DATA  READ 

32  BIT  PORT 

+001  1 

0001BD56 

OOOEOOOE 

SUPR  DATA  HRITE 

32  BIT  PORT 

+0012 

0001BD58 

04E204E2 

SUPR  DATA  HRITE 

32  BIT  PORT 

+0013 

OOO4OCO0 

02E204E2 

SUPR  PGRM  READ 

8  BIT  PORT 

+0014 

00040C09 

AFE204E2 

SUPR  PGRM  READ 

B  BIT  PORT 

+0015 

00040C0A 

FFE204A2 

SUPR  PGRM  READ 

8  BIT  PORT 

+0016 

00040COB 

F5000402 

SUPR  PGRM  READ 

8  BIT  PORT 

+0017 

0001BD5A 

00700070 

SUPR  DATA  HRITE 

32  BIT  PORT 

Figure  17  Timing  waveforms  for  interrupt  level  4  operation. 
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F.  Interrupt  Level  6  (Software  Abort)  test. 

The  interrupt  routine  used  in  this  test  is  the  one  in  Reference  1.  The  state  listing 
and  timing  waveforms  are  given  in  Figures  18  and  19,  respectively.  The  interrupt  is 
handled  in  the  same  way  as  the  level  4  interrupt.  The  only  difference  is  the  level  of  the 
interrupt  and  the  exception  vector  address  ($00000078).  The  interrupt  is  generated  by 
driving  both  !IPL2  and  IIPLl  lines  low,  simultaneously  (Sec  Figure  19).  The 
MC68020  does  not  ackowledge  the  interrupt,  immediately.  Instead,  it  drives  the 
UPEND  line  low  and  completes  the  current  instruction  execution.  When  the  current 
instruction  is  completed,  the  MC68020  enters  the  interrupt  acknowledge  cycle  and 
negates  the  UPEND  line  (X  marker  position  in  Figure  19).  Address  line  A18  is  shown 
as  a  sample  of  the  address  bus,  during  this  activity.  It  is  asserted  first  during  the 
interrupt  acknowledge  cycle  and  second  to  access  the  routine  in  the  ROM. 


68020 

STATE  LISTING 

Label  > 

ADDR 

DATA 

STAT 

DSACK 

Base  > 

Hex 

Hex 

Symbol 

Symbol 

+0000 

00022000 

95044380 

CPU 

SPACE 

16 

BIT  PORT 

+0001 

00022010 

00000007 

CPU 

SPACE 

32 

BIT  PORT 

+0002 

0000 1 008 

6000FFFB 

SUPR 

PERM 

READ 

32 

BIT  PORT 

+0003 

00022000 

0900FFFB 

CPU 

SPACE 

16 

BIT  PORT 

+0004 

00001000 

6000FFF2 

SUPR 

PGRM 

READ 

32 

BIT  PORT 

+0005 

FFFFFFFD 

0000FFF2 

CPU 

SPACE 

WAIT  STATE 

+0006 

0001FFD4 

20042004 

SUPR 

DATA 

WRITE 

32 

BIT  PORT 

+0007 

00000078 

00040CCC 

SUPR 

DATA 

READ 

32 

BIT  PORT 

+0008 

0001FFD6 

00000000 

SUPR 

DATA 

WRITE 

32 

BIT  PORT 

+0009 

0001FFD8 

10081008 

SUPR 

DATA 

WRITE 

32 

BIT  PORT 

+0010 

00040CCC 

00081008 

SUPR 

PGRM 

READ 

8 

BIT  PORT 

+001 1 

00040CCO 

7C081008 

SUPR 

PGRM 

READ 

8 

BIT  PORT 

+0012 

e0040CCG 

07081008 

SUPR 

PGRM 

READ 

8 

BIT  PORT 

+0013 

00040CCF 

00081008 

SUPR 

PGRM 

READ 

8 

BIT  PORT 

+0014 

0001FFDA 

00760078 

SUPR 

DATA 

WRITE 

32 

BIT  PORT 

Figure  18  The  state  listing  for  interrupt  level  6  test. 
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Figure  19  Timing  waveforms  for  interrupt  level  6  test. 


V.  CONCLUSIONS 


A.  The  current  implementation  of  the  ECB 


The  ECB  designed  and  implemented  in  this  thesis  can  be  used  as  a 
state-of-the-art  tool  for  teaching  and  research.  The  ECB  requires  an  easy-to-install 
firmware  for  initializing  and  handling  the  ccnnmunication  with  a  control  device  (see 
Reference  1).  The  result  of  this  effort  is  a  new  and  powerful  microprocessor  which  is 
simple.  In  comparison  with  the  ECB  previously  designed  by  Motorola  (using  MfiSOOO 
microprocessor),  the  new  design  has  the  following  advantages; 


•  The  number  of  components  on  the  board  is  less.  (10  components  -  not 

including  the  components  for  the  external  I/O  device  interface.  The  Motorola 
ECB  has  61  components). 


•  Availability  of  the  coprocessor  which  provides  a  very  fast  computation 
mechnism  for  floating  point  operations.  It  can  also  be  used  as  a  tool  for 
teaching. 


•  Higher  clock  speed  (quadrupled  to  16  MHz). 


•  Only  one  intelligent  terminal  is  required  to  run  the  board,  (the  Motorola 
ECB  requires  two,  one  intelligent  terminal  to  assemble  and  download  user 
programs  and  one  dumb  terminal  to  run  the  downloaded  program). 


It  has  the  following  disadvantages. 


•  Slow  rate  of  response  to  user  commands.  (This  is  due  to  the  fact  that  the  user 
commands  and  the  result  of  these  conunands  have  to  be  passed  back  and  forth 
between  the  board  and  the  intelligent  terminal  via  the  9600  baud  rate  RS-232 
interface.  This  is  a  trade-off  between  the  number  of  componentsAcrminals  and 
the  speed.  Transmission  or  reception  of  a  byte  takes  10.4  ms  with  a  9600 
baud  rate). 
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•  Cache  memory  has  not  been  enabled.  (  Disabling  die  cache  memory  allowed 
us  to  monitor  the  external  bus  activity  during  developmoit  of  the  ECB  and 
helped  troubleshoot  die  failures  and  learn  die  details  of  jvocessor 
operation  during  implementaticMi). 


B.  Future  Improvements 

The  ECB  has  a  provisioi  to  install  TTL  series  74244  and  74245  line  drivers/ 
receivers  for  an  external  I/O  device  (8  bit).  All  the  pads  and  holes  are  available  to 
install  the  line  drivers^eceivers.  The  ccmnection  diagram  is  given  in  Appendix  G. 

The  byte  I/O  feature  has  not  been  implemented  and  tested. 


27 


APPENDIX  A:  MC68020  SIGNAL  DESCRIPTION 


This  section  describes  the  function  of  each  individual  signal  or  group  of  signals  and 
their  utilization  on  the  ECB. 

1.  Function  Code  Signals  (  FCO  through  FC2  ) 

•  Three-state  outputs. 

•  Identify  the  processor  and  address  space  of  the  current  bus  cycle,  as  shown  in 
Table  2. 


Table  2  Function  Code  Encodings 


rc2 

ret 

fee 

ADDRESS  SPACE 

1 

« 

e 

UNDEflNED 

« 

« 

1 

USER  DATA  SPACE 

« 

I 

e 

USER  PROCRAI  SPACE 

t 

1 

1 

UNDEflNED 

1 

( 

e 

UNDEFINED 

1 

t 

1 

SUPERVISOR  OAIA  SPACE 

1 

I 

e 

SUPERVISOR  PROCRAV  SPACE 

1 

I 

1 

CPU  SPACE 

•  Not  utilized  on  the  ECB. 

2.  Address  Bus  Signals  (  AO  through  A31  ) 

•  Three  state  outputs. 

•  Provide  the  address,  up  to  4  gigabytes,  for  a  bus  transfer  in  all  address  spaces 
except  for  CPU  space  in  which  the  bus  specifies  CPU  related  information. 

•  On  the  ECB; 

A18,  A17,  A15  generate  chip  enable  signals  for  coprocessor  and  memory. 
A19,  A15  are  used  to  transmit  RS-232  data. 
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A19,  A17  are  used  to  receive  RS-232  data. 

Al,  AO  are  used  to  generate  read/write  signals  for  RAM. 

A14  through  AO  are  used  to  address  ROM. 

A14  through  A2  are  used  to  address  RAM. 

A31  through  A20  are  not  used. 

3.  Data  Bus  Signals  (  DO  through  D31  ) 

•  Three  state  inputs/outputs. 

•  Provides  exchange  of  data  between  MC68020  and  external  devices. 

•  On  the  ECB; 

D31  through  D24  are  connected  to  ROM. 

D31  through  DO  are  connected  to  RAM  and  coprocessor. 

4.  Transfer  Size  Signals  (  SIZO,  SlZl  ) 


•  Three  state  outputs. 

•  Indicate  the  remaining  number  of  bytes  of  an  operand  to  be  transfered  in  a  bus 
cycle,  as  shown  in  Table  3. 


Table  3  Transfer  Size 
Encodings 


TRANSFER 

SIZE 

SIZl 

SIZl 

BYTE 

• 

1 

tORO 

1 

1 

3  BYTE 

1 

I 

EONC  TORO 

t 

1 

•  On  the  ECB; 

SIZO,  SIZl  are  used  to  generate  read/write  signals  for  RAM. 
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5.  External  Cycle  Start  (  !ECS  ) 


•  Output 

•  In  case  of  a  cache  miss,  indicates  the  start  of  an  external  bus  cycle,  if  validated 
by  Address  Strobe  (!AS)  later. 

•  Not  utilized  on  the  ECB. 

6.  Operand  Cycle  Start  (  !OCS  ) 

•  Output 

•  Indicates  the  start  of  an  instruction  prefetch  or  an  operand  transfer  with  the  same 
restrictions  as  in  !ECS. 

•  Not  utilized  on  the  ECB. 

7.  Read-Modify-Write  Cycle  (  !RMC  ) 

•  Three  state  output 

•  Indicates  an  indivisible  read  modify  write  cycle  on  the  bus. 

•  Not  utilized  on  the  ECB. 


8.  Address  Strobe  (  !AS  ) 


•  Three  state  output 

•  Indicates  the  availability  of  valid  function  code,  address,  size,  and  read/write 
inf(xmation  on  the  bus. 

•  On  the  ECB; 

Used  as  a  synchronization  pulse  in  the  generation  of  DSACKO,  DSACKl,  and 
PHANTOM  signals. 


9.  Data  Strobe  (  IDS) 


•  Three  state  output 

•  In  a  write  cycle,  indicates  that  valid  data  is  available  on  the  data  bus. 
In  a  read  cycle,  signals  the  slave  device  to  drive  the  data  bus. 

•  On  the  ECB; 

Used  to  generate  chip  select  and  read/write  signals  for  memory. 
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10.  ReadAVrite  (  R/IW  ) 


•  Three  state  output 

•  High  level  on  this  output  indicates  a  read  from  an  external  device, 

Low  level  indicates  a  write  to  an  external  device. 

•  On  the  ECB; 

Used  to  generate  chip  select,  read/write  and  output  enable  signals  for  memory. 

11.  Data  Buffer  Enable  (  IDBEN  ) 

•  Three  state  output 

•  Provides  an  enable  to  external  data  buffers. 

•  Not  utilized  on  the  ECB. 


12.  Data  Transfer  and  Size  Acknowledge  (  IDSACKO,  IDSACKl  ) 


•  Inputs 

•  Indicates  the  port  size  of  the  external  device  and  the  completion  of  the  data 
transfer,  as  shown  in  Table  4. 


Table  4  DSACK  codes. 


DSACK1 

osACKe 

BUS  CTCIE  STATUS 

1 

1 

INSERT  1AII  STATES 

1 

« 

8  BIT  PORI  -  crClE  COUPIETED 

1 

1 

16  BIT  PORT  -  CYCLE  COMPLETED 

1 

« 

32  BIT  PORT  -  CYCLE  COMPLETED 

•  On  the  ECB; 

Indicate  an  8-bit  port  size  for  ROM,  32-bit  port  size  for  RAM,  and  coprocessor. 


13.  Cache  Disable  (  ICDIS  ) 

•  Input 

•  Allows  to  enable/disable  the  on-chip  cache  memory. 

•  On  the  ECB; 

Pulled  down  to  ground  to  disable  the  cache. 


31 


14.  Interrupt  Priority  Level  Signals  (  IIPLO,  tlPLl,  IIPL2  ) 
•  Inputs 


•  Indicate  the  level  of  the  interrupt  requested  by  an  external  device,  as  shown  in 
Table  5. 


Table  5  Interrupt  Priority  and  mask  levels 


ItVEL 

IKl 

IPLI 

il>LI 

RCOUCSICD 

MASK 

1 

I 

1 

e 

K/A 

\ 

1 

* 

1 

t 

I 

t 

1 

2 

#- 1 

1 

t 

« 

3 

•  -2 

• 

1 

1 

4 

•  -3 

1 

1 

♦ 

5 

•  -4 

t 

1 

e 

•  -5 

1 

e 

« 

7 

»-7 

•  On  the  ECB; 

Interrupt  level  4  (  !IPL2  )  is  used  for  RS-232  communication. 
Interrupt  level  6  (  !IPL2,  !IPL1  )  is  used  for  software  abort. 


15.  Interrupt  Pending  (  IIPEND  ) 


•  Output 

•  Indicates  that  the  active  interrupt  privity  level  is  higher  than  the  level  of  the 
interrupt  mask  in  the  status  register  or  indicates  Ae  recognition  of  a  non¬ 
maskable  interrupt. 

•  Not  utilized  on  the  ECB. 


16.  Autovector  (  lAVEC  ) 


•  Input 

•  When  asserted,  interrupt  vector  is  generated  internally  during  an  interrupt 
acknowledge  cycle. 

•  On  the  ECB; 

All  interrupts  are  autovectored. 
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17.  Bus  Request  (  !BR  ) 


•  Input 

•  Indicates  that  some  device  other  than  MC68020  has  a  request  to  become  a  bus 
master. 

•  Not  utilized  cm  the  ECB. 


18.  Bus  Grant  (  !BG  ) 

•  Output 

•  Indicates  that  MC68020  will  release  the  bus  upcm  the  completion  of  die  current 
bus  cycle  for  use  by  the  device  issuing  a  Bus  Request. 

•  Not  utilized  on  the  ECB. 


19.  Bus  Grant  Acknowledge  (  IBGACK  ) 


•  Input 

•  Indicates  that  some  device  other  than  MC68020  has  beccnne  a  bus  master. 

•  Not  utilized  on  the  ECB. 


20.  Reset  (  ’RESET  ) 


•  Open  drain  input  and  output. 

•  When  used  as  an  input,  MC68020  enters  reset  excepticm  prcmessing; 

when  used  as  an  output,  external  devices  are  reset,  and  no  internal  acticm  is 
taken. 

•  On  the  ECB; 

Used  as  an  input  only  to  reset  the  processor  during  power  up  or  reset  by  the  user. 


21.  Halt  (  IHALT  ) 


•  Open  drain  input  and  output. 

•  When  used  as  an  input,  MC68020  halts; 

previous  bus  cycle  information  is  kept  on  read/wtite,  function  code,  size 
signals  and  on  Ae  address  bus. 

The  data  bus  stays  in  high  impedance  state. 

All  ccmtrol  signals  stay  inactive. 

When  used  as  an  output,  signals  the  external  devices  that  MC68020  has  halted. 
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•  On  the  ECB; 

Assoted  at  the  same  time  as  the  reset  input,  during  power  iq>  or  reset. 
22.  Bus  Error  (  IBERR  ) 

•  Input 

•  Indicates  a  problem  widi  the  current  bus  cycle. 

•  Not  utilized  on  the  ECB. 


23.Clock  (  CLK  ) 


•  TTL-compatible  input 

•  On  the  ECB; 

16  MHz  clock  is  applied  to  this  input. 
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Table  6  MC68020  AC  Electrical  Characteristics.  (Copied  from  Rrference  2) 


Figure  20  MC68020  Read  Cycle  Timing  Diagram.  (Copied  from  Reference  2) 


36 


so  SI  S2  S3  S4  S5 


Figure  21  MC68020  Write  Cycle  Timing  Diagram.  (Copied  from  Reference  2) 
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APPENDIX  B:  MC68881  SIGNAL  DESCRIPnON 


This  section  describes  the  hmction  of  each  individual  signal  and  its 
utilization  on  the  ECB. 

1.  Address  Bus  Signals  (  AO  through  A4  ) 

•  Inputs. 

•  Are  used  by  the  main  processor  to  access  any  coprocessor  interface  register  in  the 
CPU  address  space.  AO  is  used  to  ccmfigiure  the  data  bus  size. 

•  On  the  ECB; 

AO  is  coimected  to  high  in  order  to  configure  a  32  bit  bus  coimection. 

A1  through  A4  are  coimected  to  corresponding  address  bus  pins  of  MC68020. 

2.  Data  Bus  Signals  (  DO  through  D31  ) 

•  Three  state  inputs/outputs. 

•  Provides  exchange  of  data  between  MC6888 1  and  the  main  processor. 

•  On  the  ECB; 

D31  through  DO  are  connected  to  corresponding  data  bus  pins  of 
the  MC68020. 

3.  Address  Strobe  (  !AS  ) 

•  Input 

•  Indicates  the  availability  of  valid  address,  chip  select  and  read/write  signals. 

•  On  the  ECB; 

is  directly  coimected  to  !AS  pin  of  MC68020. 
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4.  Size  Signal  (ISIZE) 


•  Input. 

•  Used  in  conjunction  with  AO  configure  the  data  bus  size  as  follows: 


Table  7  MC6888 1  Data  Bus 
Size  Encoding. 


Al 

SIZE 

data  bus  size 

X 

0 

B  BIT 

0 

1 

IS  BIT 

t 

1 

3Z  BIT 

•  On  the  ECB; 

is  connected  to  high  in  order  to  configure  a  32  bit  bus  connection. 

5.  Chip  Select  (  !CS  ) 

•  Input 

•  Enables  the  main  processor  access  to  the  coprocessor  interface  registers. 

•  On  the  ECB; 

is  generated  by  the  address  bits  A18,  A17  and  AIS. 

6.  ReadAYrite  (  R/!W  ) 

•  Input 

•  Indicates  the  direction  of  bus  activity. 

Low  level:  a  read  firom  MC6888 1. 

High  level:  a  write  to  MC6888 1. 

•  On  the  ECB; 

is  directly  connected  to  R/IW  output  of  MC68020. 
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7.  Data  Strobe  (  !DS  ) 


•  Input 

•  Indicates  a  valid  data  on  the  data  bus,  during  a  write  cycle. 

•  On  the  ECB; 

is  directly  connected  to  !DS  pin  of  MC68020. 

8.  Data  Size  And  Acknowledge  (  IDSACKO,  IDSACKl  ) 

•  Three  state  output 

•  Indicates  the  port  size  of  the  coprocessor  interface  and  the  completion  of  the  bus 
cycle  to  the  main  processor. 

•  On  the  ECB; 

are  directly  connected  to  IDSACKO  and  IDSACKl  pins  of  MC68020. 
They  report  a  port  size  of  32  bits  to  the  main  processor. 

9.  Reset  (  IRESET  ) 

•  Input. 

•  Initializes  the  floating  point  data  registers  and  clears  the  floating  point  control, 
status  and  instruction  address  registers. 

•  On  the  ECB; 

is  connected  to  the  same  reset  circuit  as  MC68020. 

10.  Sense  Device  (  ISENSE  ) 

•  Output. 

•  Can  be  utilized  as  an  indication  to  the  presence  of  MC6888 1. 

•  Not  utilized  on  the  ECB. 

11.  Clock  (  CLK  ) 

•  TTL  compatible  input 

•  On  the  ECB; 

MC68020  clock  is  applied  to  this  input. 
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Table  8  MC6888 1  AC  Electrical  Characteristics.  (Copied  from  Reference  3) 
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Figure  22  MC6888 1  Read  Cycle  Timing  Diagram.  (Copied  from  Reference  3) 
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Figure  23  MC6888 1  Write  Cycle  Timing  Diagram  (Copied  from  Reference  3) 
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APPENDIX  C:  MC68020  BUS  OPERATION 


This  section  describes  the  basic  bus  operation  of  MC68020. 


1.  Operand  Transfers 

Unlike  the  old  M68000  family  members,  there  is  no  restriction  on  the  alignment  of 
data  in  memory,  but  the  instruction  alignment  on  word  boundaries  is  enforced  in  order 
to  obtain  maximum  efficiency.  MC68020  can  transfer  byte,  word,  and  longword 
operands  to/firom  8,  16,  and  32-bit  data  ports  signalled  by  the  data  transfer  and  size 
acknowledge  (  IDSACKO,  iDSACKl  )  inputs.  A  32-bit  port  uses  all  data  lines  D31 
through  DO.  Communication  with  a  16-bit  port  is  provided  over  D31  through  D16,  and 
with  an  8-bit  port  over  D31  through  D24.  It  takes  MC68020  one  bus  cycle  to  fetch  a 
long  word  from  a  32-bit  port,  two  bus  cycles  fi:om  a  16-bit  port  and  four  bus  cycles 
from  an  8-bit  port.  The  bytes  of  an  operand  of  any  size  can  be  routed  to  any  byte 
position  of  32-bit  data  bus,  according  to  the  size  outputs  and  the  address  lines  AO  and 
Al.  By  the  use  of  this  scheme,  the  operand  alignment  restriction  is  eliminated.  Table  9 
shows  how  the  bytes  of  an  operand  is  multiplexed  on  the  data  bus. 


Table  9  MC68020  External  Data  Bus  Multiplexing. 


TRANSrCR 

Size 

SIZE  1  ADDRESS 

OPERAND  PDSniON 

su 

Q 

D3I;02A 

DZ3;DI( 

DIS;DI 

D7-DI 

BflE 

• 

I 

X 

0P3 

0P3 

OP  3 

0P3 

lORD 

1 

1 

X 

1 

0P2 

0P3 

OP? 

0P3 

1 

« 

X 

1 

OPZ 

OPZ 

OP  3 

OPZ 

3  Bri( 

1 

I 

< 

1 

DPI 

0P2 

0P3 

OPI 

1 

1 

< 

1 

OPI 

OP  1 

OPZ 

IP3 

1 

1 

1 

t 

CPI 

OPZ 

OPI 

OPZ 

1 

1 

1 

1 

OPI 

OPI 

OPZ 

OPI 

lONC  TORO 

f 

f 

• 

* 

0P« 

OPI 

OPZ 

0P3 

f 

• 

n 

1 

DPI 

OPI 

OPI 

OPZ 

• 

1 

1 

» 

OPO 

OPI 

OPI 

OPI 

• 

• 

1 

t 

OPT 

OPO 

OPI 

OPI 

The  operand  representation  and  size/offset  encodings  for  external  data  bus  multiplexing 
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are  shown  in  Figure  24. 


OPERAND  REPRESENTATION  FOR  EXTERNAL  DATA  BUS  MULTIPLEXING 


TRANSFER 

SI2C 

SI2t 

SIZI 

•  BYI£ 

1 

■■ 

vono 

1 

n 

3  BYIE 

1 

LOKC  «0R0 

1 

_ 1 
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OFFSET 

A1 

Al 

BYTE 

• 

1 

BORO 

1 

I 

3  BYTE 

1 

1 

LONC  BORO 

I 

1 

SIZE  AND  OFFSET  ENCODING  FOR  EXTERNAL  DATA  BUS  MULTIPLEXING 


Figure  24  Operand  representation  and  size/offset  encodings 


The  following  are  the  examples  of  long  word  transfers  to  a  16-bit,  and  to  an  8-bit  data 
bus. 


BUS  CYCLE 

SIZI 

SIZO 

A) 

AO 

(SAtKI 

DSACKO 

031  OAT*  BUS  DIB 

1 

0 

• 

0 

1 

1 

1 

OPB 

OPI 

2 

1 

t 

1 

0 

t 

1 

OPZ 

0P3 

Figure  25  Long  word  transfer  to  16-bit  data  bus 


BUS  CYCLE 

SIZI 

SlZf 

Al 

*0 

(SaCki 

D$A(Ki 

031  data  bus  024 

1 

0 

1 

1 

1 

1 

0 

OPI 

2 

1 

1 

1 

1 

1 

0 

OPI 

3 

1 

1 

1 

1 

1 

0 

0P2 

4 

0 

1 

1 

\ 

1 

0 

0P3 

Figure  26  Long  word  transfer  to  8-bit  data  bus 
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An  address  error  exception  occurs  when  an  instruction  fetch  at  an  odd  address  is 
attempted,  although  no  restriction  is  imposed  on  data  alignment.  The  next  two  figures 
shows  the  misaligned  longword/word  transfers  to  32/16  bit  buses,  respectively. 


BUS  CTCLC 

SIZI 

SIZI 

A2 

At 

Al 

OSACKI 

bUtKt 

DJI  DATA  BUS  Olj 

1 

• 

n 
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1 

1 

IQQ 

QQI 

DO 

J 

1 

mm 

\ 

1 

1 

1 

i 

DO 

QQ 

QQI 

Figure  27  Misaligned  longword  transfer  to  32-bit  data  bus 


BUS  CTCLC 

SIZI 

SIZI 

A2 

At 

Al 

OSACK 1 

DSacki 

DJI  DAIA  bus  DIB 

1 

1 

I 
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1 

1 

• 

I 

XXX 

0P2 

i 

\ 

0 

_l_j 

1 

1 

1 

0P3 

XXX 

Figure  28  Misaligned  word  transfer  to  16-bit  data  bus 
2.  Bus  Operation 


•  Read  Cycle:  Data  is  received  from  external  device  in  accordance  with  the 
following  sequence  of  events: 

MC68020  External  Device 

Sets  Read/Write  to  Read 
Puts  Address  onto  address  bus 
Drives  Size  outputs 
Assets  External  Cycle  Start/ 

Operand  Cycle  Start 
Asserts  Address  Strobe 
Asserts  Data  Strobe 
Asserts  Data  Buffer  Enable 

Decodes  address 
Puts  data  onto  data  bus 
Assets  Data  Transfer  and 
Size  Acknowledge 


Latches  data 
Negates  Data  Strobe 
Negates  Address  Strobe 
Negates  Data  Buffer  Enable 
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Removes  Data  from  the  bus 
Negates  Data  Transfer  and 
Size  Acknowledge 


Starts  new  bus  cycle 


•  Write  Cycle;  Data  is  sent  to  external  device  in  accordance  with  the  following 
sequence  of  events: 

MC68020  External  Device 

Sets  Read/Write  to  Write 
Eirives  Function  Codes 
Puts  Address  onto  address  bus 
Drives  Size  outputs 
Asserts  External  Cycle  Start/ 

Operand  Cycle  Start 
Asserts  Address  Strobe 
Asserts  Data  Strobe 
Asserts  Data  Buffer  Enable 

Decodes  address 
Latches  data  from  data  bus 
Asserts  Data  Transfer  and 
Size  Acknowledge 

Negates  Data  Strobe 
Negates  Address  Strobe 
Removes  Data  from  data  bus 
Negates  Data  Buffer  Enable 


Negates  Data  Transfer  and 
Size  Acknowledge 


Starts  new  bus  cycle 


•  Read-Modify-Write  Cycle:  During  this  cycle,  data  is  read  from  memory,  it  is 
modified  in  ALU  and  written  back  to  the  same  address.  This  bus  cycle  is 
indivisible,  that  is,  MC68020  does  not  release  the  bus  until  the  whole  cycle  is 
completed.  This  feature  is  utilized  in  multi  processesing  by  the  instructions  Test 
And  Set  (TAS)  and  Compare  And  Swap  (CAS,  CAS2).  For  detailed  explanation, 
refer  to  Reference  2. 
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3.  Interrupt  Operation 


MC68020  has  seven  interrupt  levels  of  which  level  seven  is  the  highest.  The  level 
of  requested  interrupt  is  signalled  to  the  processor  via  interrupt  priority  level  signals 
IPL2-IPL0.  Level  zero  (IPL2-1PL0  =  HHH)  means  no  interrupt  requested.  If  the  level 
of  requested  interrupt  is  between  one  and  six,  the  interrupt  level  is  compared  against 
the  interrupt  mask  level  in  the  status  register.  If  the  requested  interrupt  level  is  less 
than  or  equal  to  the  mask  level,  the  interrupt  is  ignored.  Otherwise  the  interrupt  is 
processed.  The  level  seven  interrupts  are  non-maskable;  that  is,  they  are  immediately 
processed  regardless  of  the  interrupt  mask  level  in  the  status  register. 

The  following  two  rules  guarantee  the  processing  of  an  interrupt: 

•  Except  for  the  level  seven  interrupt,  the  interrupt  level  should  be  higher  than  the 
interrupt  mask  level  in  the  status  register. 

•  IPLO  through  IPL2  should  stay  at  the  requested  level,  until  the  interrupt  is 
acknowledged  by  MC68020. 

It  is  also  possible  that  an  interrupt  request  of  a  diuration  as  short  as  two  clock  cycles 
can  be  processed.  A  recognized  interrupt  is  made  pending  and  is  processed  at  the  next 
instruction  boimdary,  unless  a  higher  level  interrupt  is  valid.  After  the  interrupt  is 
made  pending,  the  processor  first  determines  the  starting  location  of  the  intemipt 
handling  routine  pointed  by  the  interrupt  vector  number.  This  vector  number  can  be 
generated  internally  or  can  be  provided  by  the  intemipt  requesting  device  through  the 
data  bus  in  the  interrupt  acknowledge  cycle. 

The  following  is  the  flowchart  for  Interrupt  Acknowledge  Sequence; 


•  Interrupt  Acknowledge  Sequence 

MC68020  DEVICE 

Requests  interrupt 

COTipares  the  requested  interrupt 
level  with  the  mask  level. 

Sets  Read/Write  output  to  Read 
Sets  Function  Code  to  7  (CPU  Space) 

Sets  A1-A3  to  the  recognized  level. 

Sets  Size  outputs  to  Byte. 

Asserts  Address  Strobe  and  Data  Strobe 

Either 

Places  vector  number  on  data  bus. 
Asserts  Data  Transfer  and 
Size  Acknowledge. 


48 


Asserts  lAVEC  for  internal  generation 
of  interrupt  vector  number. 


Gets  the  interrupt  vector  number. 

Negates  Address  Strobe  and  Data  Strobe. 

Negates  Data  Transfer  and 

Size  Acknowledge,  if  assoted. 


Processes  the  interrupt. 


In  case  of  a  spurious  interrupt,  that  is,  an  interrupt  request  is  recognized,  but 
IDSACKX  or  lAVEC  signal  is  not  assoted  by  dre  external  device,  then  the  external 
circuit  should  assert  IBERR  signal.  This  terminates  the  interrupt  vector  acqusition  and 
causes  MC68020  to  fetch  spurious  interrupt  vector  and  to  start  exception  processing. 

4.  Breakpoint  Acknowledge  Cycle 

This  cycle  is  initiated  by  the  execution  of  a  breakpoint  instruction  during  which 
MC68020  reads  a  word  from  CPU  space.  Upon  the  termination  of  the  cycle  by 
IDSACKx,  the  processor  replaces  the  breakpoint  instruction  by  the  data  read  from  the 
data  bus  and  continue  to  execute  that  instruction.  If  the  cycle  is  terminated  by  IBERR, 
then  the  processor  continues  with  processing  an  illegal  instruction  exception. 

5.  Coprocessor  Operations 

MC68020  communicates  with  the  coprocessor  by  performing  CPU  space  accesses. 
During  a  CPU  access,  address  bus  contains  the  access  information,  instead  of  an 
address.  The  lines  A16  through  A19  contain  0010  to  specify  coprocessor  operation,  and 
the  coprocessor  ID  number  to  be  accessed  is  encoded  on  the  lines  A13  through  A15. 
The  lines  AO  through  A5  indicate  the  coprocessor  interface  register  to  be  accessed. 
The  coprocessor  ID  number  0  is  belong  to  MC68020  memory  management  unit. 

6.  Bus  Error  Operation 

MC68020  is  provided  with  a  Bus  Error  input  which  is  used  to  terminate  the  current 
bus  cycle,  in  case  of  a  handshake  failure.  The  signal  this  input  should  be  generated 
externally,  after  the  maximum  time  period  between  the  assertion  of  IAS  and  IDSACKx. 
Bus  error  input  is  also  used  to  suspend  the  execution  of  an  instruction,  if  an  invalid 
memory  access  is  detected. 
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MC68020  may  start  to  process  the  bus  error  excq>tion  immediately,  in  case  of  a  data 
space  access,  or  may  defer  processing  it,  if  the  bus  error  occurs  during  an  instructimi 
prefetch.  In  the  second  case,  the  bus  error  exception  will  occur,  whra  the  faulted  data 
is  actually  to  be  executed. 

7.  Retry  Operation 

If  both  !BERR  and  .'HALT  inputs  are  asserted  externally,  MC68020  will  rerun  the 
previous  bus  cycle  after  the  negation  of  diese  two  signals.  There  is  no  restriction  cm  the 
type  of  bus  cycle  to  be  retried. 

8.  Halt  Operation 

MC68020  will  stop  all  external  bus  activity  when  the  IHALT  input  is  asserted.  The 
internal  operation  of  the  processor  is  not  affected  by  the  !HALT  input.  For  example,  a 
program  stored  in  the  cache  memory  will  continue  to  run  regardless  of  the  IHALT 
input.  Stepping  through  the  processor  operation  one  bus  cycle  at  a  time  is  also  possible 
by  asserting  the  IHALT  input  when  the  processm  starts  a  bus  cycle.  As  long  as  the 
IHALT  input  remains  asserted,  the  current  bus  cycle  will  be  completed,  but  the  next 
cycle  will  not  start.  In  order  to  step  through  the  next  bus  cycle,  the  IHALT  input 
should  be  negated  and  then  asserted  again  after  the  bus  cycle  starts. 

9.  Double  Bus  Fault 

Double  bus  fault  is  an  address  or  bus  error  which  occurs  during  the  exception 
processing  for  an  address  error,  bus  error,  or  reset  exception.  When  a  double  bus  fault 
occurs,  the  processor  halts  and  the  IHALT  line  is  asserted.  Then  the  processor  can  only 
be  started  by  an  external  reset. 

10.  Reset  Operation 

The  reset  citation  is  bidirectional,  the  processor  can  reset  the  external  devices,  or 
the  external  circuitry  can  reset  the  processor,  hi  order  to  reset  the  processor,  the 
IRESET  input  should  be  asserted  at  least  100  ms.  Then  the  processor  loads  the 
interrupt  stack  pointer  and  the  program  counter  from  the  long-word  addresses 
$00000000  and  $00000004  respectively.  Trace  is  disabled,  privileged  states  is  set  to 
supervisor-interrupt  state  by  clearing/setting  the  relevant  bits  in  the  status  register.  The 
vectm*  base  register  is  set  to  $00000000  and  the  cache  is  disabled  by  clearing  the  cache 
enable  bit  in  the  cache  control  register.  The  other  registers  remain  unaffected. 
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The  processor  resets  the  external  devices  by  executing  a  RESET  instruction,  which 
asserts  the  IRESET  line  for  512  clock  cycles.  Nothing  inside  the  processor  is  affected 
by  executing  the  RESET  instruction. 
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APPENDIX  D:  PROCESSING  STATES  OF  MC68020 


This  section  describes  the  operation  of  the  processor  in  two  subsecti(ms,  the 
privilege  states  and  the  exception  processing. 

1.  Privilege  States 

MC68020  has  two  levels  of  privilege,  the  supervisor  level  and  the  user  level.  The 
supervisor  level  has  a  higher  privilege  than  the  user  level  in  that  the  user  level  is  not 
allowed  to  access  all  the  program  and  data  areas  and  to  execute  all  the  instructions. 
This  separation  of  privileges  provides  security  in  the  system. 

a.  Supervisor  States 

The  S  bit  in  the  status  register  determines  the  privilege  level  of  the  processor. 
When  the  S  bh  is  set,  the  processor  runs  in  supervisor  state  and  can  execute  all  the 
instructions.  The  M  bit  in  the  status  register  allows  the  separation  of  the  supervisor 
stack  for  user  and  interrupt-associated  tasks.  This  separation  increases  efficiency  in 
multi-tasking  environment.  When  the  M  bit  is  set,  the  system  stack  pointer  references 
the  master  stack  pointer,  otherwise  the  interrupt  stack  pointer  is  used  as  the  system 
stack  pointer.  Referencing  the  system  stack  pointer  is  the  cmly  operation  affected  by  the 
status  of  the  M  bit.  After  reset,  the  S  bit  is  set  and  the  M  bit  is  cleared.  If  the  M  bit  is 
already  set  and  an  interrupt  occurs,  then  the  processor  saves  the  status  of  the  M  bit  and 
clears  it  to  process  the  exception  for  intmupt.  When  processor  runs  in  the  supervisor 
state,  the  S  and  M  bits  can  be  manipulated  by  the  instructions  that  modify  the  status 
register.  The  supervisor  state  is  encoded  as  5  (data)  and  6  (program)  on  the  function 
code  pins.  By  executing  the  instructions  RTE,  MOVE  to  SR,  ANDI  to  SR  and  EORI  to 
SR,  the  processor  can  switch  from  the  supervisor  state  to  the  user  state. 

b.  User  State 

When  the  S  bit  in  the  status  registo*  is  set  to  zero,  MC68020  runs  in  the  user  state 
in  which  the  instructions  that  have  an  impact  on  the  system  are  not  allowed  to  execute. 
In  the  user  state,  the  system  stack  pointer  references  the  user  stack  pointer.  The  user 


52 


state  is  encoded  as  1  (data)  and  2  (program)  on  the  fimcticMi  code  pins.  The  exception 
processing  is  the  only  way  to  switch  from  the  user  state  to  the  supervisor  state. 

2.  Exception  Processing 

a.  General  Information 

An  exception  can  be  generated  internally  by  instructions,  address  errors, 
tracing  or  breakpoints;  it  can  also  be  generated  externally  by  interrupts,  bus  errors,  reset 
or  errors  detected  by  coprocessor.  The  following  are  the  four  steps  to  process  an 
exception  as  explained  in  the  section  "MC68020  Overview": 

•  Make  an  internal  copy  and  set/clear  the  required  bits  of  the  status  register  for 
exception  processing. 

•  Determine  the  exception  vector. 

•  Save  the  current  processor  context  on  the  active  supervisor  stack. 

•  Get  the  new  processor  context  and  proceed  with  the  instruction  processing. 

The  internal  copy  of  the  status  register  is  saved  on  the  exception  stack  frame 
created  in  order  to  save  the  current  processor  context.  Depending  on  the  type  of  the 
exception,  MC68020  can  aeate  exception  stack  frames  in  six  different  formats.  All  of 
the  six  frames  have  at  least  four  fields  that  contain 

•  Status  Register 

•  Program  Counter 

•  Format  of  the  fi:ame 

•  Vector  Offset 

Some  exception  stack  frames  have  another  field  which  contains  additi<»ial  processor 
information.  This  information  can  be  2,  6,  12  or  42  words  in  length.  Detailed 
information  on  the  exceptirxi  stack  frames  can  be  found  at  the  end  of  this  appendix. 

After  saving  the  current  content  of  status  register,  the  processor  is  switched  to  the 
supervisin'  state  by  setting  the  S  bit.  The  trace  bits  are  cleared  in  order  to  prevent  the 
exception  handler  from  being  hindered  by  tracing. 
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In  the  second  step,  the  MC68020  detoinines  the  excepticHi  vector  number.  The 
vector  number  is  obtained  by  a  read  from  CPU  space  for  interrupts  (if  the  interrupt  is 
not  autovectored).  TTie  coprocessor  provides  the  vector  number  in  exception  primitive 
response,  if  it  detects  an  exception.  The  vector  numbers  for  all  other  exceptions  are 
generated  internally. 


In  the  third  step,  if  the  exception  is  not  reset,  an  exception  stack  frame  is  created 
on  the  active  supervisor  stack  and  the  current  processor  context  is  saved  in  this  frame. 
With  the  M  bit  set,  if  the  excepticm  is  an  interrupt,  then  the  MC68020  clears  the  M  bit 
and  creates  another  stack  frame  on  die  ^temipt  stack. 


In  the  last  step,  the  exception  vector  offset  is  calculated  by  multiplying  the 
exception  vector  number  by  four  (number  of  bytes  in  a  long-word).  The  calculated 
exception  vector  offset  is  then  added  to  the  contents  of  the  vector  base  register  ( 
default  value  after  reset  is  00000000  Hex)  to  locate  the  exception  vector  address.  The 
contents  of  the  exception  vector  address  is  loaded  into  die  program  counter  (for  reset 
exception,  the  interrupt  stack  pointer  is  also  loaded  from  the  exception  vector  address) 
and  the  instruction  at  the  address  pointed  by  the  program  counter  is  fetched  and  the 
instruction  execution  resumes.  All  the  exceptions  are  grouped  and  are  given  priorities  to 
determine  the  order  in  which  simultaneous  exceptions  will  be  handled.  The  exception 
groups  and  the  level  of  priorities  are  as  follows; 


•  Group  0:  Priority  0  Reset 


•  Group  1:  Priority  1  Address  Error 
Priority  2  Bus  Error 


•  Group  2:  Priority  3  BKPT  #n 

CALLM 

CHK 

CHK2 

cp  Mid-Instruction 

cp  Protocol  Violation 

cp  TRAPcc 

Divide-By-Zero 

RTE 

RTM 

TRAP  #n 

TRAPV 
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•  Group  3:  Priority  4  Illegal  instruction 

Line  A 

Unimplemented  Line  F 
Privilege  violation 
cp  Pre-Instruction 

•  Group  4:  Priority  5  cp  Post-Instruction 

Priority  6  Trace 
Priority  7  Interrupt 


b.  The  sources  of  exceptions 


(1)  Reset 


This  is  the  highest  priority  exception  which  initializes  die  system  and  recovers  the 
system  from  a  catastrophic  failure.  The  current  process  can  not  be  recovered  after  a 
reset.  When  an  external  reset  signal  is  s^plied  to  the  IRESET  input,  MC68020  takes 


the  following  steps; 


•  The  status  register: 

Trace  bits  TO,  T1  are  cleared  (tracing  disabled). 

S  bit  is  set,  M  bit  is  cleared  (supervisor  interrupt  state). 
Interrupt  mask  level  is  set  to  level  seven. 


The  vector  base  register: 
is  initialized  to 


Hex. 


•  The  cache  control  register: 
is  initialized  to  00000000  Hex. 


•  The  vector  number: 

is  internally  generated  to  point  the  reset  exception  vector  at  zero  offset  in  the 
supervisor  pro^am  space.  The  length  of  reset  exception  vector  is  two  long  words, 
the  first  of  which  holds  the  initial  value  for  interrupt  stack  pointer  and  the  second 
the  initial  value  for  the  program  counter. 

•  Program  execution  starts  with  the  instruction  fetched  from  die  address  pointed  by 
the  program  counter. 


When  a  RESET  instruction  is  executed,  no  intnual  registers  of  MC68020  are  affected, 
only  the  IRESET  line  is  asserted  for  512  clock  cycle  to  reset  the  external  devices.  The 
program  execution  continues  with  the  next  instruction. 


(2)  Address  Error 

When  an  attempt  is  made  to  fetch  an  instruction  from  an  odd  address,  dien  the 
address  error  exception  occurs,  and  the  bus  cycle  is  not  executed.  If  the  occurance  of 
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the  address  error  coincides  with  the  processing  of  a  bus  error,  address  error  or  reset 
exception,  then  the  process^  halts. 

(3)  Bus  Error 

When  the  IBERR  input  is  asserted  by  the  external  logic  during  a  bus  cycle,  dien 
the  current  bus  cycle  is  aborted.  The  exception  processing  begins  immediately  if  the 
aborted  bus  cycle  is  a  data  space  access.  The  processor  defers  the  exception  processing 
until  the  prefetched  instruction  is  actually  needed,  if  the  aborted  cycle  is  an  instruction 
prefetch.  Depending  on  when  the  bus  error  occurs  during  a  bus  cycle,  MC68020  creates 
one  of  two  exception  stack  frames  for  the  bus  error.  If  the  bus  error  occurs  in  the 
middle  of  instruction  execution,  then  the  larger  stack  frame  (Format  B  Hex)  is  required, 
otherwise  exception  stack  frame  in  Format  A  Hex  is  created.  As  in  the  address  error,  if 
the  bus  error  takes  place  during  the  exception  processing  for  an  address  error,  bus  error, 
reset,  or  RTE  instruction  execution,  the  MC68020  halts. 

(4)  Instruction  Trap 

The  detection  of  an  abnormal  condition  during  instruction  execution  or  executing 
some  specific  instructions  cause  a  trap.  The  exceptiwi  vector  number  is  generated 
internally  for  all  instruction  traps  (the  TRAP  #n  instruction  has  part  of  the  vector 
number  in  itself).  The  instructions  that  specifically  generate  a  trap  are  as  follows: 

•  TRAP  #n  :  When  executed,  forces  an  exception.  By  using  this  instruction,  user 

programs  can  make  system  calls. 

•  TRAPcc,  TRAPV,  cpTRAPcc,  CHK,  CHK2  :  An  exception  is  forced  by  these 

instructions,  if  the  user  program  detects  a  run-time  error. 

•  DFVS,  DFVU  :  If  a  division  operation  with  a  zero  divisor  is  attempted,  these 

two  instructions  generate  a  exception. 

(5)  Breafqjoint 

Unlike  the  MC680()0  and  MC68008,  inserting  an  illegal  instruction  into  the 
breakpoint  address  and  looking  for  a  fetch  from  an  illegal  instruction  exception  vector 
address  is  not  a  reliable  way  to  determine  if  the  breakpoint  has  been  reached,  in  a 
MC68020  system.  This  is  due  to  the  allowance  of  mtiltiple  exception  vector  tables  by 
using  the  vector  base  register.  Instead,  the  opcodes  4848  Hex  through  484F  Hex  are 
used  as  breakpoint  instructions.  By  using  breakpoints,  MC68020  can  be  used  in  a 
hardware  emulator,  and  the  execution  of  a  program  in  the  on-chip  cache  memory  can 
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be  monitored  by  external  hardware. 


(6)  Format  Error 

The  MC68020  checks  the  format  of  control  data,  as  well  as  the  validity  of  the 
prefetched  instruction.  The  control  data  checked  by  the  processor  include  the  qption  and 
type  fields  in  the  module  descriptor  for  CALLM  and  RTM,  the  format  of  the  stack  for 
RTE  and  RTM,  the  format  of  the  coprocessor  save  area  for  cpRESTORE.  If  the  format 
check  of  the  control  data  fails,  then  the  MC68020  generates  a  format  error  exceptitm, 
and  aeates  a  short  format  frame  (Format  0  Hex).  The  program  counter  value  saved  on 
the  satck  frame  points  to  the  address  of  the  instruction  that  detected  the  format  error. 


(7)  Illegal  or  Unimplemented  Instruction 

Any  word  bit  pattern  that  does  not  match  with  the  bit  pattern  of  the  first  word  of  a 
legal  MC68020  instruction  is  called  illegal  instruction.  Illegal  instructions  also  include 
the  MOVEC  instruction,  if  it  has  an  undefined  register  specification  in  the  first 
extension  word.  There  are  two  types  of  unimplemented  instructions,  A-line  opcodes 
and  F-iine  opcodes,  where  A  and  F  correspond  to  the  numbers  that  bits  15  through  12 
of  the  opcode  represent  in  hexadecimal  form.  F-line  opcodes  are  used  for  coprocessor 
instructions.  Illegal  instructions  and  unimplemented  instructions  have  distinct  exception 
vectors  which  allows  the  emulation  of  unimplemented  instructions  more  efficiently. 


(8)  Privilege  Violation 

An  attempt  to  execute  one  of  the  following  instructions  in  the  user  privilege  state 
will  cause  an  exception; 


•  ANDI  to  SR 
EORI  to  SR 
ORI  to  SR 
MOVE  to  SR 
MOVE  from  SR 


MOVE  USP 

MOVEC 

MOVES 

RESET 

RTE 


cpSAVE 

cpRESTORE 

STOP 


Also  it  is  possible  that  an  exception  will  occur  when  the  coprocessor  requests  a 
privilege  check,  while  MC68020  is  in  the  user  state. 
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Both  the  next  instruction  address  and  the  address  of  the  instruction  that  caused 
privilege  violation  are  saved  on  the  exception  stack  frame. 


(9)  Tracing 

By  setting  the  trace  bits  in  the  status  register,  programs  can  be  traced  on 
instruction-by-instruction  basis.  The  MC68020  can  also  trace  the  instructions  that 
change  the  sequential  flow  of  the  program.  The  trace  bits  indicate  the  type  of  tracing  as 
shown  in  Table  10: 


Table  10  Trace  Bit 
Encoding. 


Tracing  allows  a  debugger  program,  like  the  one  written  in  Reference  1,  to  monitor 
the  execution  of  a  test  program. 

In  no  trace  mode,  the  instructions  are  executed  normally.  When  the  trace  bits  are 
set  to  trace  branch  mode,  the  instructions  that  change  the  sequential  flow  of  the 
program  will  be  traced.  These  instructions  include  all  branches,  jumps,  instruction  traps, 
returns  and  those  that  affect  the  status  register  contents.  If  trace  bits  are  set  to  trace  all 
mode,  every  instruction  will  be  traced.  The  exception  processing  for  a  trace  starts  after 
the  completion  of  the  traced  instruction  and  before  the  execution  of  next  instruction. 
For  trace  exception  processing,  MC68020  creates  a  stack  frame  in  Format  2  Hex  and 
clears  the  trace  bits.  Both  the  address  of  the  next  instruction  and  the  address  of  the 
traced  instruction  are  saved  on  the  stack  frame.  If  the  STOP  instruction  begins  the 
execution,  when  T1  bit  is  set,  then  the  stop  instruction  will  not  take  effect. 

{10)  Interrupts 

The  interrupt  mask  level  in  the  status  register  determines  whether  an  interrupt  will 
be  processed  or  ignored.  If  the  requested  interrupt  has  a  higher  priority  level  than  the 
interrupt  mask  level,  then  the  interrupt  is  made  pending  and  the  processing  begins  at 
the  next  instruction  boimdary,  otherwise  the  interrupt  is  ignored.  The  level  seven 
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inteinipt  is  an  exception  to  this  case,  it  can  not  be  inhibited  by  the  intemq>t  mask 
level. 

During  an  interrupt  acknowledge  cycle,  the  level  of  the  interrupt  being  acknoixdedged  is 
put  (XI  the  address  lines  A1-A3,  and  if  the  intemq>t  is  ncX  autovectored,  the  vect(v 
number  is  fetched  fr(xn  the  external  device.  If  the  interrupt  is  autovectored,  tlK 
MC68020  internally  generates  a  vector  numbo'  which  ctxrespcnuls  to  the  level  of  the 
interrupt.  If  a  bus  error  is  detected,  then  the  spurious  interrupt  vector  is  fetched. 

(11)  Return  From  Exception 

The  Return  Rrom  Exc^ptitxi  (RTE)  instiucticxi  is  used  to  return  to  the  prcKessor 
ccxitext  prior  to  the  exception,  whenever  it  is  possible.  The  processor  examines  the 
stack  frame  created  for  the  exception  in  ordtt  to  check  the  validity  of  the  frame  and  to 
determine  the  type  of  context  rest(xation.  In  case  of  a  format  ot  bus  errcx'  during  the 
execution  of  the  RTE  instruction,  anodier  stack  frame  is  created  above  the  frame  whicfr 
was  going  to  be  used. 


c.  Exception  Stack  Frames 


Impending  on  the  type  of  the  exception,  the  MC68020  creates  one  of  six 
stack  frames  which  are  described  in  this  section. 


(1)  Normal  Four  Word  Stack  Frame  (Format  $0) 

•  Created  by 

Interrupts 

F(xmat  Errors 

TRAP  #n  Instructions 

Illegal  and  Unimplemented  Instructi(xts 

Privilege  Violations 

Coprocessor  pre-instruction  Exceptions 


•  The  format  of  the  frame  (see  Figure  29); 

SP  =  Status  Register 

SP  +  02  Hex  =  Program  Counter 

SP  +  06  Hex  =  Format  Number  (0000  Hex)  +  Vector  Offset  (12  Bits) 
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Figure  29  Normal  four-word  stack  frame 


•  The  program  counter  value  (SP402  Hex)  is  the  address  of  the  instruction  that 
caused  the  exception  or  the  address  of  the  next  instruction. 


(2)  Throwaway  Four-Word  Stack  Frame  (Format  $1) 

•  Created  if  the  supervisor  state  is  changed  to  interrupt  state  from  master  state  (M 
bit  is  cleared)  during  exception  processing  for  an  interrupt. 

•  The  format  of  the  frame  (see  Figure  30); 

SP  =  Status  Register 

SP  +  02  Hex  =  Program  Counter 

SP  +  06  Hex  =  Format  Number  (0001  Hex)  +  Vector  Offset  (12  Bits) 


Figure  30  Throwaway  four-word  stack  frame 


•  The  program  counter  value  (SP+02  Hex)  might  be  the  address  of  the  instruction 
that  caused  the  exception,  the  address  of  the  next  instruction,  or  coprocessor  mid¬ 
instruction  stack  frame. 


(3)  Normal  Six  Word  Stack  Frame  (Format  $2) 

•  Created  by 

Coprocessor  post-instruction  exceptions 
CHK  and  CHK2  instructions 
cpTRAPcc,  TRAPcc  and  TRAPV  instructions 
Trace 
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Zero  divide 

•  The  format  of  the  frame  (see  Figure  31): 

SP  =  Status  Register 

SP  +  02  Hex  =  Program  Counter 

SP  +  06  Hex  =  Format  Number  (0001  Hex)  +  Vector  Ofrset  (12  Bits) 
SP  +  08  Hex  =  Instruction  Address  (32  Bits) 


Figure  31  Normal  six-word  stack  frame 


•  The  program  counter  value  (SP+02  Hex)  is  the  address  of  the  next  instruction,  or 
the  address  to  be  returned  by  RTE  instruction. 

•  The  instruction  address  value  is  the  address  of  the  instruction  that  caused  the 
exception. 


(4)  Coprocessor  Mid-instruction  Exception  Stack  Frame  (Format  $9) 

•  Created  when 

"Take  mid-instruction  exception"  coprocessor  primitive  is  read  while  the 
MC68020  is  processing  a  coprocessor  instruction. 

The  MC68020  detects  a  protocol  violation  during  a  coprocessor  instruction 
processing. 

"Null,  come  again  with  interrupts  allowed"  primitive  is  read,  and  the  MC68020 
detects  a  pending  interrupt. 


•  The  format  of  the  frame  (see  Figure  32): 

SP  =  Status  Register 

SP  +  02  Hex  =  Program  Counter 

SP  +  06  Hex  =  Format  Number  (0010  Hex)  +  Vector  Offset  (12  Bits) 
SP  +  08  Hex  =  Instruction  Address  (32  Bits) 

SP  +  OC  Hex  =  Internal  Registers  (4  Words) 
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SP*|»2  _ 

SP«|I6  ~i  •  (  T 

sp«l»e 


STATUS  PCCISICR 


PPOCRAU  COUNTtR 


veCTDR  OFFSET 


INSTRUCTION  ADDRESS 


INTERNAL  RECISTERS 


SP<tl2 


Figure  32  Coprocessor  mid-instruction  exception 
stack  frame 


•  The  program  counter  value  (SP+02  Hex)  is  the  address  of  the  next  instruction. 

•  The  instruction  address  value  is  the  address  of  the  instruction  that  caused  the 
exception. 


(5)  Short  Bus  Cycle  Stack  Frame  (Format  $A) 

•  Created  when 

the  MC68020  detects  a  bus  cycle  fault,  and  recognizes  it  is  at  an  instruction 
boundary. 

•  The  format  of  the  frame  (see  Figure  33); 

SP  =  Status  Register 

SP  +  02  Hex  =  Program  Counter 

SP  +  06  Hex  =  Format  Number  (0101  Hex)  +  Vector  Offset  (12  Bits) 

SP  +  08  Hex  =  Internal  Register 
SP  +  OA  Hex  =  Special  Status  Word 
SP  +  OC  Hex  =  Instruction  Pipe  Stage  C 
SP  +  OE  Hex  =  Instruction  Pipe  Stage  B 
SP  +  10  Hex  =  Data  Cycle  Fault  Address 
SP  +  14  Hex  =  Internal  Register 
SP  +  16  Hex  =  Internal  Register 
SP  +  18  Hex  =  Data  Ou^ut  Buffer 
SP  +  1C  Hex  =  Internal  Register 
SP  +  IE  Hex  =  Internal  Register 
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15  1 J 

n  0 

SP 

STATUS  RECISTER 

SP<t*2 

$P«tl6 

till 

VECTOR  OrrSET 

SP<tlB 

internal  register 

SP<tlA 

SPECIAL  STATUS  lORO 

sp<tic 

instruction  pipe  stage  c 

SP<t«E 

INSTRUCTION  PIPE  STAGE  B 

$p<t1* 

DATA  crcir  FAULT  ADDfiFSS 

SP«tH 

INTERNAL  REGISTER 

SP<tlC 

INTERNAL  REGISTER 

SP»St8 

PI^FFFR 

SP.»IC 

INTERNAL  REGISTER 

SP.ftE 

internal  register 

Figure  33  Short  bus  cycle  fault  stack  frame 
•  The  program  counter  value  (SP+02  Hex)  is  the  address  of  the  next  instruction. 


(6)  Long  Bus  Cycle  Stack  Frame  (Format  B  Hex) 
•  Created  when 


the  MC68020  detects  a  bus  cycle  fault,  and  recognizes  it  is  not  at  an  instruction 
boundary. 

•  The  format  of  the  frame  (see  Figure  34): 


SP  =  Status  Register  (Word) 

SP  +  02  Hex  =  Program  Counter  (2  Words) 

SP  +  06  Hex  =  Format  Number  (0101  Hex)  +  Vector  Offset  (12  Bits) 
SP  +  08  Hex  =  Internal  Register  (Word) 

SP  +  OA  Hex  =  Special  Status  Word  (Word) 

SP  +  OC  Hex  =  Instruction  Pipe  Stage  C  (Word) 

SP  +  OE  Hex  =  Instruction  Pipe  Stage  B  (Word) 

SP  +  10  Hex  =  Data  Cycle  Fault  Address  (2  Words) 

SP  +  14  Hex  =  Internal  Registers  (2  Words) 

SP  +  18  Hex  =  Data  Output  Buffer  (2  Words) 

SP  +  1C  Hex  =  Internal  Registers  (4  Words) 

SP  +  24  Hex  =  Stage  B  Address  (2  Words) 

SP  +  28  Hex  =  Internal  Registers  (2  Words) 

SP  +  2C  Hex  =  Data  Input  Buffer  (2  Words) 

SP  +  30  Hex  =  Internal  Registers  (22  Words) 
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SP 

STATUS  HeClSTCR 

$P*t»2 

couNtrfi 

SP<t(S 

till 

VECTOR  OFFSET  { 

SP>tt8 

INICRNAL  IttCISTER 

SP'tt* 

SPEtlAL  STATUS  lORO 

sp<t«e 

INSTRUCTION  PIPE  STACE  C 

SP«t«C 

INSTRUCTION  PIPE  STACE  B 

SP*|H 

crcit  TAUl r 

SP«t14 

INTERNAL  REGISTER 

SP'itt 

INTERNAL  REGISTER 

SP<t18 

QAIA  DliTFtIT  RllprfD 

SP<t  1C 

INTERNAL  REGISTERS 

SP>t22 

4  VORDS 

SP<(24 

ft  Anncrcc 

sp*t2e 

INTERNAL  REGISTER 

SP<t2A 

INTERNAL  REGISTER 

SP<t2C 

INPUT  Rurrrp 

SP*til 

internal  REGISTERS 

22  lORDS 

SP<tSA 

Figure  34  Long  bus  cycle  fault  stack  frame 

•  The  program  counter  value  (SP+02  Hex)  is  the  address  of  the  instruction  that  was 
executing  when  the  bus  cycle  fault  occured  (not  necessarily  the  instruction  that 
caused  the  bus  error). 


d.  Coprocessor-related  exceptions 

These  exceptions  can  be  divided  in  two  groups,  coprocessor-detected  exceptions  and 
main  processor-detected  exceptions.  The  main  difference  between  two  groups  is  the 
point  at  which  the  exception  processing  starts.  Due  to  concurrent  instruction  execution, 
the  processing  for  many  of  the  coprocessor-detected  exceptions  does  not  start  until  the 
main  processor  completes  the  execution  of  the  offending  instruction  and  attempts  to 
execute  the  next  instruction.  The  exception  processing  for  all  main  processor  detected 
exceptions  and  some  coprocessor-detected  excqrtion  starts  during  the  execution  of  the 
offending  instruction.  ’ 
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(1)  The  Coprocessor-Detected  Exceptions. 

The  coprocessor-detected  exceptions  can  be  either  related  to  the  communication 
with  the  main  processor  or  to  the  executicm  of  a  floating-point  instruction.  The 
exception  vector  numbers  and  address  offsets  for  coprocessor-related  exceptions  are  as 
follows: 

•  Vector  Vector 

Number  Offset  (Hex)  Assignment 


7 

1C 

FTRAPcc  instruction 

11 

2C 

F-Line  emulator 

13 

34 

CoprcxxssOT  Protocol  Violation 

48 

CO 

Branch  or  Set  on  Unordred  Condition 

49 

C4 

Inexact  Result 

50 

C8 

Floating-point  divide  by  zero 

51 

cc 

Underflow 

52 

DO 

Operand  Error 

53 

D4 

Overflow 

54 

D8 

Signalling  Not-A-Number 

The  execution  of  a  floating-point  instruction  can  cause  one  or  more  of  eight 
exceptions.  The  exceptions  caused  by  the  instruction  "move  floating-point  data  register 
to  an  external  location"  are  called  mid-instruction  exceptions.  All  the  other  instruction 
exceptions  are  pre-instruction  exceptions. 


•  Signalling  Not-A-Number:  The  data  types  defined  by  the  user  or  non-IEEE 

data  types  cause  SNAN  exception.  This  exception  is 
never  caused  as  a  result  of  an  operation.  The 
instructions  that  do  not  modify  the  status  bits  must 
be  used  in  SNAN  trap  handler  to  hinder  further 
exceptions. 

•  Operand  Error:  If  the  current  operation  has  no  mathematical 

interpretation  for  the  given  operands,  then  an  operand 
error  occurs. 

•  Overflow:  When  the  exponent  of  the  result  is  greater  than  or 

equal  to  the  maximum  value  for  die  specified  framat, 
then  overflow  condition  can  be  detected.  But  the 
exception  occurs  if  the  destination  is  in  one  of  the 
floating-point  formats.  Overflows  for  destinations  in 
integer  or  packed  decimal  format,  are  included  as 
operand  errors. 

•  Underflow:  When  the  exponent  of  the  result  is  less  than  or 

equal  to  the  minimum  value  for  the  specified  format, 
then  overflow  condition  can  be  detected.  But  the 
exception  occurs  if  the  destination  is  in  one  of  the 
floating-point  f(»mats.  Overflows  for  destinations  in 
integer  cm:  packed  decimal  format,  are  included  as 
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operand  errcffs. 

•  Divide-By-Zero:  A  division  with  za:o  divider  or  a  transcendental 

function  which  is  asymptotic  with  infinity  will  cause 
Divide-By  Zero  exception. 

•  Inexact  Result  (INEX2):  This  exceptitm  will  occur,  if  the  result  of  an 

operation,  except  for  an  operation  with  packed  decimal 
operand,  has  a  mantissa  Aat  can  not  be  represented 
in  the  specified  rounding  precision  or  the  destination 
precision. 

•  Inexact  Result  (INEXl):  This  exception  will  occur,  if  the  result  of  an 

operation  with  packed  decimal  opnand,  has  a  mantissa 
that  can  not  be  represented  in  the  specified  rounding 
precision  at  the  d«tination  precision. 

•  Branch/Set  on  Unordered:  The  conditicmal  instructions  with  the  following 

IEEE  non-aware  branch  condition  predicates  can  cause 
BSUN  exception. 


Table  11  IEEE  non-aware  branch  condition 
predicates 


CT 

CREAICR  THAN 

NCt 

NOI  CREAICR  THAN 

ce 

GREATER  THAN  OR  EOUAL 

NCt 

NOI  GREATER  THAN  OR  EQUAL 

II 

LESS  THAN 

NLI 

NOI  LESS  than 

U 

LESS  THAN  OR  EQUAL 

KLC 

NOI  LESS  than  or  EOUAL 

CL 

CRCAIER  OR  LESS  IHAN 

KCl 

NOI  CREAICR  OR  LESS  THAN 

CLC 

GREATER  OR  LESS  OR  EQUAL 

NCLC 

NOT  GREATER  OR  LESS  OR  EOUAL 

SF 

SIGNALLING  TRUE 

SI 

signalling  false 

sec 

SIGNALLING  EQUAL 

SNE 

SIGNALLING  NOI  EQUAL 

(2)  Coprocessor  Detected  Protocol  Violations 
A  protocol  violation  occurs,  when  the  command,  condition,  register  select  or 
operand  CIR  is  accessed  unexpectedly  as  follows: 

•  When  a  write  to  the  command  or  condition  CIR  is  expected,  but  the  register 
select  or  operand  CIR  is  accessed. 

•  When  a  read  from  the  register  select  or  operand  CIR  is  expected,  but  a  write  to 
the  command,  condition  or  operand  CIR  occurs. 

•  When  a  write  to  the  operand  CIR  is  expected,  but  either  a  write  to  the  command 
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or  condition  CIR  or  a  read  from  the  register  select  or  operand  CIR  occurs.After 
detecting  a  protocol  violation,  the  MC6888 1  encodes  the  response  CIR  with  the  take 
pre-instruction  primitive  so  that  the  MC68020  will  terminate  the  dialog. 


Table  12  MC68020  Exception  Vector  Table. 


VCCtOR 

NUUBCII 

(OCCIIIAl) 

VtCIOR 

orrsci 

(HEX) 

VCCtOR 

ASSUNIENI 

f 

til 

RCSCI  ;  INItlAl  1$P 

I 

i 

■HB 

1(1$  tiftlft - 1 

4 

'  III 

s 

SH 

6 

SIS 

7 

ll{ 

1 

HttH 

9 

muam 

TRAtt  1 

li 

utam 

1  1 

■UBI 

13 

mtkm 

UNASSICNED | 

13 

i}i 

ii 

ISi 

a 

mmi 

■UJH 

MM 

UNASSICKEO 

loH 

mSm 

muam 

■{{■I 

li 

in 

3i 

9S8 

17 

mtam 

Us 

lEI 

3i 

3t 

III 

■BUHI 

■  l){ 

III 

1RAP  fl  -  1}  INSIXUCIION  VCCtORS 

HDHi 

lie 

1(1 

“rrmsoR 

<3 

l(l 

d(i  tktii  "“T 

it 

ICI 

D2 

Si 

l(( 

(PCP  UNtl  ^ 

52 

IDS 

tut  it>(RR 

ij 

BlUB 

"(pcrivri 

(i(i  SIlAli 

ss 

MTm«  HI 

SI 

Id 

S3 

1(4 

Si 

•  IB 

■■ 

UNASSURED 

■DM 

ire 

MMI 

USER  OtriNCO 

MSMl 

ire 
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Table  13  MC68020  Extensions  To  M68000 
Family  Instructions 


INSTRUCTION 

EXTENSION 

Bcc 

32  BIT  OISPIACENENT 

BT  1 1  X  1 

BIT  FIELD  INSTRUCTIONS 

BKPT 

NEf  INSTRUCTION 

BRA 

32  BIT  OiSPLACEMENT 

esR 

32  BIT  DISPLACENENT 

CALLM 

NEI  INSTRUCTION 

CAS. CAS2 

NCt  INSTRUCTION 

CHK 

32  BII  OPERANDS 

CHK2 

NCt  INSTRUCTION 

CMPI 

PC  RELATIVE  ADDRESSING  MODE 

CHP2 

NCt  INSIRUCTION 

Yp 

COPROCESSOR  INSTRUCTIONS 

OIVS/DIVU 

32  BIT  AND  S4  BIT  OPERANDS 

EXTB 

8  BII  EXTEND  TO  32  DITS 

LINK 

32  BIT  OISPLACEMENT 

MOYEC 

NCt  CONTROL  REGISTERS 

MULS/MULU 

32  BIT  OPERANDS 

PACK 

NCt  INSTRUCTION 

RTU 

Ntt  INSTRUCTION 

TSI 

PC  RELATIVE  ADDRESSING  MODE 

TRAPct 

NCt  INSIRUCTION 

UNPK 

NEt  INSTRUCTION 

Table  14  MC68020’s  Improved  Features. 


A00RE55  BUS 


INSIRUCIION  CACHE 


COPROCESSOR  INIEREACE 


DATA  alignment 


CONTROL  REGISTERS 


stack  pointers 


status  register 


ADDRESS  SPACE 


STACK  FRAMES 


IMPROVEMENT 


.  le  OR  32  BITS  (DYNAMIC  SIZING) 


32  BITS 


128  lORDS 


IMPltMCNItO  IN  MICROCODE 


ONLY  INSTRUCTIONS  fORD  ALIGNED 


Src,  DFC.  VBR,  CACR,  CAAR 


USP.  SSP  (  ISP  onO  MSP  | 


II/TI.  $.  M.  I  MASK,  COND.  CODE 


CPU  SPACE  <  FUNCTION  CODE  7 


t«.  It.  12.  »».  I*.  IB 


up/iot  BOUNDS  PCA  I  PUSH  crrccrive  aoopcss 
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APPENDIX  E:  MC68881  REGISTERS  AND  DATA  TYPES 

I.  MC68881  REGISTERS 

The  programming  model  of  the  MC6888 1  contains  four  groups  of  registers. 

A.  Floating  Point  Data  Registers  (FP0*FP7) 

The  eight  80-bit  floating  point  data  registers  are  used  to  store  external  operands  in 
extended  precision  format.  All  external  operands  are  converted  to  extended  precision 
numbers,  regardless  of  their  data  format,  before  they  are  stored  in  the  floating  point 
data  registers.  The  higher  order  16  bits  are  not  used  in  the  extended  precision  data 
format. 

•  The  bit  field  descriptions  for  extended  precision  data  format; 

0  through  51  :  Fraction 

52  through  62  :  Biased  Exponent 

63  :  Sign 

64  through  79  :  Not  used 

B.  Floating  Point  Control  Register  (FPCR) 

This  32-bit  register  is  used  to  enable/disable  traps  for  floating  point  exceptions  and 
to  set  rounding  mode  (Figure  35).  The  high-(»’der  16  bits  are  reserved  for  future  use. 
The  low-order  16  bits  contain  exceptirm  enable  l^e  and  mode  control  byte.  The  user 
can  read  frtim  and  write  to  the  control  register  (with  high-order  word  zero  for  future 
compatibility). 


Figure  35  Floating  Point  Control  Register 
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1.  Exception  Enable  Byte 

The  exception  enable  byte  contain  eight  enable  bits  for  each  class  of  floating  point 
exceptions  as  follows  (see  Figure  36): 

•  Exception  enable  byte  bit  description  : 

Bit  15  :  BSUN  (Branch/Set  on  Unordoed) 

Bit  14  :  SNAN  (Signalling  Not  A  Number) 

Bit  13  :  OPERR  (O^and  Error) 

Bit  12  :  OVFL  (Overflow) 

Bit  11  :  UNFL  (Underflow) 

Bit  10  :  DZ  (Divide  by  Zero) 

Bit  9  :  INEX2  (Inexact  Operation) 

Bit  8  :  INEXl  (Inexact  Decimal  Input) 


t] 

14 

u 

12 

II 

l« 

1 

\ 

t 

1  esuN 

SNAN 

OPERR 

OVFL 

UNFL 

02 

INEXl 

INEX2 

Figure  36  FPCR  Exception  Enable  Byte 


The  bit  numbers  in  Figure  36  refer  to  the  bit  numbers  of  low-order  word  of  the 
control  register.  The  status  of  any  bit  position  determines  whether  the  corresponding 
exception  will  be  processed  or  not.  To  ensure  that  the  exception  will  be  processed,  the 
bit  positions  for  this  exception  in  both  the  control  and  status  register  should  be  set.  The 
enable  byte  in  the  control  register  should  be  set  before  an  exception  occurs.  Setting  any 
enable  bit  in  the  control  register  after  an  exception  occurs  does  not  have  any  effect  in 
processing  the  exception,  regardless  of  the  corresponding  bit  value  in  the  status  register. 
The  following  exceptions  can  be  caused  simultaneously  by  executing  a  single 
instruction. 

•  SNAN  and  INEXl 

•  OPERR  and  INEX2 

•  OPERR  and  INEXl 

•  OVFL  and  B^X2  and/or  INEXl 

•  UNFL  and  INEX2  and/or  INEXl 


In  case  of  multiple  exceptions,  only  the  higher  priority  exception  will  be  processed 
and  the  other(s)  will  be  ignored.  The  bit  position  of  an  exception  determines  its 
priority,  BSUN  (Bit  15)  has  the  highest  priority. 
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2.  Mode  Control  Byte 

This  byte  controls  the  rounding  mode  and  precision.  If  all  the  bits  are  zero  then 
IEEE  default  is  selected. 


Bits  7  and  6  determine  the  rounding  precision  as  follows: 
•  Bit  7  Bit  6  Precision 

0  0  Extended  (round  to  64  bits) 

0  1  Single  (round  to  24  bits) 

1  0  Double  (round  to  S3  bits) 

1  1  Undefined 


Bits  5  and  4  determine  the  rounding  mode  as  follows: 
•  Bit  5  Bit  4  Mode 

0  0  To  nearest 

0  1  Toward  zero 

1  0  Toward  minus  infinity 

1  1  Toward  plus  infinity 


Figure  37  FPCR  Mode  Control  byte 


The  bit  numbers  in  Figure  37  refer  to  the  bit  numbers  in  the  control  register.  The  low 
order  nibble  of  the  mode  control  byte  is  always  zero. 


C.  Floating  Point  Status  Register  (FPSR) 


This  32-bit  register  contains  condition  code  byte,  accrued  condition  code  byte, 
exception  status  byte  and  quotient  byte  (Figure  38).  The  user  can  read  from  and  write 
to  the  status  register. 
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Figure  38  FPCR  Status  Register 
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In  the  following,  the  bit  numbers  refer  to  the  bit  numbers  in  the  status  register, 
i.  Condition  Code  Byte 

AU  floating-point  arithmetic  instructions  affect  the  four  bits  contained  in  the 
status  register  (see  Figure  39).  The  bits  31  through  28  are  reserved  and  not  used.  They 
should  be  set  to  zero.  The  bits  27  through  24  are  encoded  as  follows: 

•  Condition  Code  Byte 

Bit  27  :  N  (Negative) 

Bit  26  :  Z  (Zero) 

Bit  25  :  I  (Infinity) 

Bit  24  ;  NAN  (Not  A  Number  or  Unordered) 
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Figure  39  FPSR  Condition  Code  byte 
2.  Quotient  Byte 


The  sign  and  the  seven  least  significant  bits  of  the  quotient  (unsigned)  after 
an  FMOD  or  FREM  instruction  are  stored  in  the  quotient  byte  (Figure  40). 

•  Quotient  Byte 

Bit  23  :  S  (Sign) 

Bits  22  through  16  •  Q  (Quotient) 


22  ?l 

SIGN  I 


2e  19  16 

OUOIICNI 


17  16 


Figure  40  FPSR  Quotient  byte 


The  quotient  byte  remains  unaffected  until  another  FMOD  or  FREM  instructitHi 
overwrites  the  byte  or  it  is  cleared  by  the  user. 


73 


3.  Exception  Status  Byte 


Each  bit  position  in  the  exception  status  byte  indicates  the  occurence  of  a  floating¬ 
point  exception,  during  the  last  arithmetic  or  move  instruction  (Figure  41).  This  byte  is 
cleared  before  executing  an  instruction  that  can  generate  a  floating  point  exception, 
except  for  FMOVEM  and  FMOVE  control  register  instructions.  Setting  a  bit  in  the 
exception  status  byte  by  a  user  write  does  not  cause  an  exception. 


•  Exception  status  byte  bit  description: 

Bit  15  :  BSUN  (Branch/Set  on  Unordered) 
Bit  14  :  SNAN  (Signalling  Not  A  Number) 
Bit  13  :  OPERR  (Operand  Error) 

Bit  12  ;  OVFL  (Overflow) 

Bit  11  :  UNFL  (Underflow) 

Bit  10  :  DZ  (Divide  by  Zero) 

Bit  9  :  INEX2  (Inexact  Operation) 

Bit  8  :  INEXl  inexact  Decimal  Input) 
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Figure  41  FPSR  Exception  Status  byte 


4.  Accrued  Exception  Byte 


This  byte  contains  five  exception  status  bits  that  are  logical  combinations  of  the  bits 
in  the  exception  status  byte  (Figure  42).  Unlike  the  exception  status  byte,  this  byte  is 
not  cleared  before  every  instruction  that  can  generate  an  exception.  It  is  cleared  either 
by  the  user  via  a  write  operation  to  the  status  register  or  by  the  MC6888 1  via  a  reset/  a 
null  state  size  restore  operation. 

•  Accrued  exception  byte  bit  description: 

Bit  7  :  lOP  (Invalid  Operation) 

Bit  6  :  OVFL  (Overflow) 

Bit  5  :  UNFL  (Underflow) 

Bit  4  :  DZ  (Divide  by  2^ro) 

Bit  3  :  INEX  (Inexact) 
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Figure  42  FPSR  Acciued  Exception  byte 

Bits  0  through  2  are  not  used  and  should  be  set  to  zero.  The  logical  combination  of  the 
bits  are  as  follows: 

A(IOP)  =A(IOP)  +  E(BSUN)  +  E(SNAN)  +  E(OPERR) 

A(OVFL)  =  A(OVFL)  +  E(OVFL) 

A(UNFL)  =  A(UNFL)  +  (  E(UNFL)  •  E(INEX2)  ) 

A(DZ)  =  A(DZ)  +  E(DZ) 

A(INEX)  =  A(INEX)  +  E(lNEXl)  +  E(INEX2)  +  E(OVFL) 

« 

where  A(  )  =  Accrued  Exception  Byte 
E(  )  =  Exception  Status  Byte 
’•+"  =  Logical  OR 
=  Logical  AND. 

D.  Floating  Point  Instruction  Address  Register  (FPIAR) 

I 

This  32-bit  address  register  is  loaded  with  the  address  of  the  floating-point 
instruction  before  it  is  executed.  This  is  due  to  the  non-sequential  instruction  execution 
by  the  MC68020  and  MC6888 1,  in  which  the  program  counter  value  saved  by  the 
MC68020  in  response  to  a  floating-point  exception  trap  may  not  correspond  to  the 
offending  instruction.  The  content  of  instruction  address  register  can  be  used  by 
floating-point  exception  handler  to  locate  the  instruction  that  caused  the  exception.  The 
instructions  that  do  not  modify  FPIAR  can  be  used  in  the  exception  handler  to  read  the 
FPIAR  without  changing  the  old  value.  These  instructions  are  FMOVE  to/from  FPCR, 
FPSR,  FPIAR  and  FMOVEM.  The  FPIAR  is  cleared  by  a  reset  or  null  state  size 
restore  operation. 


n.  MC68881  DATA  FORMATS  AND  TYPES 
The  MC6888 1  supports  the  following  data  formats; 
-  Byte  Integer  (  8  bits  ) 
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-  Word  Integer  (  16  bits  ) 

-  Long  Word  Integer  (  32  bits  ) 

-  Single  Precision  Real  (  32  bits  ) 

-  Double  Precision  Real  (  64  bits  ) 

-  Extended  Precision  Real  (  96  bits  ) 

-  Packed  Decimal  Real  (  96  bits  ) 

The  integer  data  formats  are  straightforward  and  they  are  not  described  in  this  section. 
The  bit  field  descriptions  for  floating  data  formats  are  as  follows  (see  Figures  43 
through  46): 

1.  Single  Real  (  32  bits  ) 

•  Bit  Fields  : 

Bit  31  ;  Sign  of  Fraction 

Bits  23  through  30  :  Exponent 

Bits  0  through  22  :  Fraction 


Figure  43  Single  Real  data 
format 


2.  Double  Real  (  64  bits  ) 

•  Bit  Fields  : 

Bit  63  :  Sign  of  Fraction 

Bits  52  through  62  :  Exponent 

Bits  0  through  51  :  Fraction 


Figure  44  Double  Real  data  ftnmat 
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3.  Extended  Real  (  96  bits  ) 


•  Bit  Fields  : 

Bit  95 

Bits  81  through  94 
Bits  64  through  80 
Bits  0  through  63 


:  Sign  of  Mantissa 
:  Exponent 

:  Not  used  (  all  zeros  ) 
:  Mantissa 


»  14 _ M 

S  I  la  BIT  CXPONtNI 
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I  t4  eil  MANTISSA 
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Figure  45  Extended  Real  data  format 


4.  Packed  Decimal  Real  (  96  bits  ) 


•  Bit  Fields  : 

Bit  95 
Bit  94 

Bits  93  through  92 
Bits  81  through  91 
Bits  64  through  80 
Bits  0  through  63 


:  Sign  of  Mantissa  ' 

:  Sign  of  Exponent 

:  Used  only  for  infinity  and  NANs,  zero  otherwise 
:  Exponent 

:  Zero  (  if  no  overflow  in  BIN  to  DEC  conversion  ) 
:  Mantissa 
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Figure  46  Packed  Decimal  Real  data  format 


The  single,  double  and  extended  precision  floating-point  data  formats  can  represent  five 
floating-point  data  types  which  have  three  parts:  Sign  of  mantissa,  Exponent  and 
Mantissa. 
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Normalized  Numbers  (Figure  47) 

Sign  of  Mantissa  :  0  or  1 

Exponent  :  Greater  Than  MINIMUM,  Less  Than  MAXIMUM 

Mantissa  :  Any  bit  pattern 


I,  I  MIN  <  EXP  <  MAX  MANTISSA  •  ANT  BIT  PATTERN 


Figure  47  Normalized  Number  format 


•  Denormalized  Numbers  (Figure  48) 

Sign  of  Mantissa  :  0  or  1 
Exponent  :  0 

Mantissa  :  Any  non-zero  bit  pattern 


1.  I  EXP  •  • 


UANIISSR  •  ANT  NON-EERO  BIT  PATTERN 


Figure  48  Denormalized  Number  Format 


•  Zeros  (Figure  49) 

Sign  of  Mantissa  ;'0  or  1 
Exponent  :  t) 

Mantissa  :  0 


B.  I  EXP  •  I 


MANTISSA  •  I 


Figure  49  Zero  format 
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•  Infinities  (Figure  50) 

Sign  of  Mantissa  ;  0  or  1 
Exponent  :  MAXIMUM 

Mantissa  :  0 


Figure  50  Infinity  format 


•  Not-A-Number  (Figure  51) 

Sign  of  Mantissa  ;  0  or  1 
Exponent  :  MAXIMUM 

Mantissa  ;  0 


«, I  cxp  •  axxiauv 


MANTISSA  «  ANT  NON-HRD  BIT  PATTERN  i 


Figure  51  Not-A-Number  format 
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APPENDIX  F;  MC68881  COPROCESSOR  INTERFACE 

A.  SIGNAL  CONNECTION  AND  COPROCESSOR  ACCESS 

The  MC68881  is  connected  to  the  main  processor  via  32-bit  data  bus,  as  shown  in 
the  Figure  52.  The  pins  AO  and  SIZE  are  both  pulled-up  to  Vcc  in  order  to  configure 
32-bit  data  bus  connection.  All  the  other  signals,  except  for  the  chip  select,  are  directly 
connected  to  the  corresponding  pins  of  the  main  processor.  The  chip  select  signal  (ICS) 
is  generated  from  A18,  A17  and  A15  by  the  external  logic  given  in  Appendix  G. 


_ 

A18 

-  1  ,  * 

MC68e2e 

AI7 

MC68S81 

AI& 

B  1  !CS 

•AS 

!05 

R/l» 

IDSACKI 

IDSACK1 

Al  -  A4 

01  -  D31 

Figure  52  MC68020/MC68881  32  bit  data  bus 
connection 


For  coprocessor  access,  the  address  lines  AO  through  A4  and  A13  through  A19  are 
encoded  as  follows  (see  Figure  53): 

•  AO  through  A4  :  Indicate  the  Coprocessor  Interface  Register  to  be  accessed 

•  A13  through  A15  :  Indicate  the  ID  number  of  the  coprocessor  to  be  accessed 

•  A16  through  A19  :  Indicate  that  CPU  space  transaction  is  coprocessor 

communications.  (0010) 
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Figure  53  CPU  space  encoding  for  coprocessor  access. 
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B.  COPROCESSOR  INTERFACE  REGISTERS 


The  main  processor  communicates  with  the  MC68881  via  a  group  of  coprocessor 
interface  registers  which  are  either  16-bit  or  32-bit  long.  The  16-bit  interface  registers 
are  placed  on  the  high  order  word  of  32-bit  data  bus  (D31-D16)  by  asserting  IDSACKl 
and  negating  IDSACKO,  regardless  of  the  value  of  Al.  Figure  54  gives  a  list  of 
coprocessor  interface  registers  with  their  address  offsets,  widths  and  read/write 
attributes.  Write  access  to  a  read-only  register  is  ignored,  whereas  read  access  to  a 
write-only  register  returns  all  ones.  The  registers  Operation  Word  (Offset  08  Hex)  and 
Operand  Address  (Offset  1C  Hex)  are  not  used  by  the  MC68881. 
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Figure  54  Coprocessor  Interface  Register  map 
a.  Response  CIR  ($00) 

The  response  CIR  is  used  to  transfer  service  requests  from  the  MC6888 1  to  the 
main  processor.  The  MC6888 1  does  not  start  instruction  execution  until  the  main 
processor  reads  the  Response  CIR  for  the  first  time  after  a  write  to  the  Command  CIR. 
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b.  Control  CIR  ($02) 


The  control  CIR  is  used  by  the  main  processor  to  issue  an  instruction  abort  or  an 
exception  acknowledge  to  the  MC6888 1.  Tile  high  order  14  bits  of  the  Control  QR  are 
not  used.  Aldiough  bits  0  and  1  are  defined  as  abort  and  exception  acknowledge, 
respectively,  it  has  the  same  effect  on  the  MC68881  to  set  bit  0  or  bit  1.  After  a 
write  to  the  Control  CIR,  the  MC6888 1  takes  the  following  steps; 

•  Terminates  die  instruction  execution. 

•  Clears  pending  exceptions,  if  any. 

•  Resets  the  bus  interface  and  gets  ready  to  begin  new  instruction  protocol. 


c.  Save  CIR  ($04) 

The  main  processor  uses  the  Save  CIR  to  issue  a  context  save  command  to  the 
MC68881  and  to  read  the  format  word  of  the  MC68881  state  frame.  A  read  from  this 
register  suspends  the  operation  currently  being  executed  by  the  MC6888 1  and  initiates 
a  state  save  operation.  If  the  current  operation  is  a  state  save  or  state  restore,  then  it 
will  not  be  suspended  by  a  read  from  the  Save  CIR. 


d.  Restore  CIR  ($06) 

The  Restore  CIR  is  used  by  the  main  processor  to  transfer  a  context  restore 
command  to  the  MC6888 1  and  to  validate  the  format  word  of  a  state  frame.  After  a 
write  to  this  register,  the  MC6888 1  stops  executing  any  operation  and  prepares  to  load 
new  internal  state  context  from  memory. 


e.  Operation  Word  CIR  ($08) 

This  register  is  not  used  by  the  MC6888 1.  A  write  to  this  register  is  ignored  and  it 
does  not  cause  a  protocol  violation. 
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/.  Command  CIR  ($0A) 


The  communication  for  executing  a  general  coprocessor  instruction  (q)GEN)  is 
initiated  by  a  write  to  the  Command  CIR  by  die  main  process^.  When  a  write  to  this 
register  is  detected,  the  MC6888 1  latches  die  data  from  the  data  bus,  and,  if  not  busy 
executing  a  previous  instruction,  the  response  CIR  is  encoded  with  the  first  primitive  of 
the  dialog  for  the  execution  of  the  new  instruction.  Odierwise,  the  latched  data  is  saved 
for  future  use  and  the  response  CIR  is  encoded  with  the  null  primitive. 

g.  Condition  CIR  ($0E) 

The  use  of  this  register  is  the  same  as  the  Command  CIR,  except  that  the  Condition 
CIR  is  for  conditional  coprocessor  instructions.  The  value  of  the  conditional  evaluation 
is  returned  to  the  main  processor  with  the  first  primitive  of  the  dialog. 

h.  Operand  CIR  ($10) 

The  32-bit  Operand  CIR  is  used  to  transfer  data  between  the  main  processor  and 
the  MC6888 1.  An  access  to  the  Operand  register  by  MC6888 1  is  legal  after  reading  the 
following  primitives: 

•  Evaluate  effective  address  and  transfer  data 

•  Transfer  multiple  coprocessor  registers 

•  Transfer  single  main  processor  register 

and  after  a  read/write  of  idle  or  busy  format  word  from/to  the  saveA’cstore  CIR.  An 
access  to  this  register  in  other  cases  causes  a  protocol  violation. 

i.  Register  Select  CIR  ($14) 

The  Register  Select  CIR  is  read  by  the  main  processOT  to  get  the  register  mask 
during  a  move  multiple  floating-point  data  register  operation.  An  access  to  this  register 
is  legal  only  just  after  issuing  a  transfer  multiple  coprocessor  registers  primitive  to  the 
main  processor.  An  access  at  any  other  time  causes  a  protocol  violation.  Only  low- 
order  eight  bits  of  this  register  are  used. 
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j.  Instruction  Address  CIR  ($18) 


The  main  processor  uses  this  32-bit  register  to  transfer  the  address  of  the  MC6888 1 
instruction  already  being  executed  when  the  PC  bit  of  any  primitive  is  set.  An  access 
to  the  Instruction  Address  CIR  at  any  time  does  not  cause  a  protocol  violation.  FPIAR 
register  is  updated,  whenever  a  write  to  the  Instructitm  Address  CIR  occurs.  A  read 
from  this  register  returns  all  ones. 

k.  Operand  Address  CIR  ($IC) 

This  register  is  not  used  by  the  MC6888 1  and  an  access  to  this  register  does  not 
cause  a  protocol  violation.  Reads  from  this  register  always  return  all  ones  and  writes 
are  ignored. 


C.  COPROCESSOR  COMMUNICATION  AND  RESPONSE  PRIMmVES 


1.  Coprocessor  Communication 

The  length  of  MC6888 1  instructions  vary  between  one  to  eight  words.  The  first  two 
words  are  called  operation  word  and  coprocessor  conunand  word.  The  words  after  the 
coprocesor  command  word  specify  the  operands.  Bits  12  through  15  in  the  operation 
word  are  always  one,  which  specify  F-line  operation  code.  Bits  9  throu^  11  indicate 
the  coprocessor  ID.  The  low  order  byte  of  the  operation  word  is  encoded  according  to 
the  type  of  the  instruction. 

The  MC68020  and  MC6888 1  follow  the  ccxnmunication  protocol,  given  below, 
during  the  execution  of  a  floating-point  instruction; 

•  The  MC68020  detects  an  F-line  opesz^oa  word  and  initiates  the  communication 
by  writing  to  the  appropriate  coprocessor  interface  register  (or  by  a  read  for 
MC6888 1  save  instruction). 

•  The  MC6888I  gives  a  response  to  the  previous  write  operation  by  writing,  what 
is  called  a  primitive,  to  the  response  CIR.  The  MC68020  then  reads  the  response 
CIR  and  proceeds  in  accordance  with  one  of  the  following  indications  by  the 
response  primitive: 

The  MC6888 1  is  busy:  Process  any  pending  interrupt, 

query  the  MC68881  again. 
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There  is  an  exception  condition  and  MC68020  is  instructed  to  take  an 
exception; 

Acknowledge  die  exception  and  initiate  die 
processing. 

The  MC6888 1  requests  service: 

Perfram  the  service  requested  by 
the  MC6888 1  such  as; 

Evaluate  the  effective  address. 

Transfer  data  between  effective  address 
and  the  MC68881. 

Query  MC6888 1  after  perfomiing  the  service. 


The  execution  of  the  coprocessor  instruction  can  start  and  MC68020  is 
released: 

Begin  the  executira  of  the  next  instruction. 

If  in  trace  mode,  take  the  trace  exception  after 
ct^rocessor  instruction  is  processed. 


2.  Response  Primitives. 


The  response  primitive  is  the  data  read  from  the  coprocessor  interface  response 
CIR.  There  are  18  response  primitives  defined  by  the  MC68000  fantily  coprocessor 
interface.  The  MC6888 1  uses  six  of  these  primitives.  The  response  primitives  are  16-bit 
words  and  have  the  following  general  format; 

•  Bit  15  (  CA  ):  Come  Again;  if  set,  the  MC68020  should  return  to  read 

the  response  CIR  again,  after  perfoiming  the 
service  requested  by  MC6888 1. 

•  Bit  14  (  PC  ):  Program  Counter;  if  set,  the  MC68020  should  immediately 

pass  die  current  PC  value  to  the  instruction 
address  CIR. 


•  Bit  13  (  DR  ):  Direction;  if  set,  it  indicates  a  main  processor  read, 

otherwise  indicates  a  main  processor  write. 

•  Bits  0  through  12;  Contains  data  dependent  on  the  individual  primitive. 
The  following  are  the  six  primitives  used  by  die  MC68881; 


a.  Null  Primitive 


The  null  primitive  provides  synchronization  and  concurrent  execution  with  the  main 
processor.  Only  five  bits  are  used  to  encode  the  null  response,  the  remaining  bits, 
except  for  bit  11,  are  all  zeros  (Figure  55): 


85 


•  Bit  i5  (  CA  )  :  Come  Again;  as  explained  above. 

•  Bit  14  (  PC  )  :  Program  Counter;  as  explained  above. 

•  Bit  8  ( lA  )  :  Interrupt  Acknowledge;  when  set,  the  main  processor  may 

process  any  pending  interrupt,  otherwise  interrupts  are  ignored. 

•  Bit  1  (  PF  )  :  Indicates  the  status  of  the  MC68881;  when  set,  the  MC68881  is 

idle.  It  is  cleared  if  the  MC6888 1  is  executing  an  instruction. 

•  Bit  0  (  TF  )  ;  Indicates  the  result  of  a  ctmditional  evaluation. 


Q 

la 

D 

El 

M 

Figure  55  Null  Format 


b.  Evaluate  Effective  Address  and  Tranffer  Data 


The  MC6888 1  uses  this  primitive  to  request  the  transfer  of  data  between 
its  data  or  control  registers  and  an  external  location,  which  can  be  either  a  memory 
location  or  a  register  of  the  main  processor.  The  bits  13  through  15  are  DR,  PC  and 
CA  bits  as  explained  in  the  general  format.  The  bit  12  is  set  to  one,  and  bit  11  to  zero 
(Figure  56). 

•  Bits  8  through  10  specifies  one  of  the  following  addressing  modes: 

000  :  Control  Alterable 

001  :  Data  Alterable 

010  :  Memory  Alterable 

Oil  :  Alterable 

100  :  Control 

101  :  Data 

110  :  Memory 

111  :  Any  Effective  Address 

If  the  class  of  effective  address  in  the  operation  word  does  not  match  the  specified 
class,  then  the  main  processor  should  write  an  abort  command  to  the  control  CER. 


UM 

la 

Q 

[Z] 

VALID  CA 

ICNCTH 

Figure  56  Evaluate  Effective  Address  and  Transfer  Data  format 
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c.  Transfer  Single  Main  Processor  Register 

The  MC68881  requests  the  transfer  of  one  main  processor  register  by  using  this 
primitive.  The  MC68020  writes  a  long  word  to  the  operand  CIR  in  response  to  this 
primi^e.  The  CA,  PC  and  DR  bits  have  the  same  functions  as  explained  above.  Bits  0 
through  2  indicate  the  register  number  to  be  transferred,  and  bit  3  (D/A)  specifies 
whether  it  is  a  data  (D/A=0)  or  address  (D/A=l)  register.  Bits  10  and  11  are  set  to  one; 
all  the  other  bits  are  zeros  (Figure  57). 


El 

a 

□J 

E 

E 

E 

QQ 
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Figure  57  Transfer  Single  Main  Processor  Register  format 

d.  Transfer  Multiple  Coprocessor  Register 

The  MC6888 1  uses  this  primitive  to  request  the  transfer  of  multiple  floating-point 
registers  to  or  from  memory.  Bits  13  through  15  are  DR,  PC  and  CA  bits.  Bits  0 
through  7  indicate  the  size,  in  bytes,  of  the  registers  to  be  transferred.  The  MC68881 
registers  are  always  12  bytes  long.  Bit  8  is  set  to  one  and  all  the  other  bits  are  zeros 
(Figure  58). 


Figure  58  Transfer  Multiple  Coprocessor  Register  format 

e.  Take  Pre-Instruction  Exception 


This  primitive  is  used  in  the  following  cases: 
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•  When  an  arithmetic  or  conditional  instruction  is  initiated,  and  there  is  a  pending 
.  exception  from  a  previously  executed  concurrent  instruction. 

•  When  an  illegal  command  word  is  ^tten  to  the  command  CIR,  or  a  protocol 
violation  occurs. 

•  When  a  conditional  instruction  which  utilizes  one  of  the  IEEE  non-aware 
conditional  predicates  is  executed,  and  the  NAN  bit  in  FPSR  is  one. 

The  CA  and  DR  bits  are  zero.  The  PC  bit  is  zero,  when  the  execution  cf  a  new 
instruction  is  preempded  by  the  exception.  The  PC  bit  is  one,  when  the  exception  is 
generated  by  an  illegal  command  word  or  when  the  exception  is  reported  during  a 
conditional  instruction  execution.  The  bits  0  through  7  indicates  the  type  of  the 
exception  which  is  used  by  the  main  processor  to  calculate  the  address  of  the  exception 
handler.  The  bits  8  and  9  are  zero,  and  all  the  other  bits  are  set  to  one  (Figure  59). 
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Figure  59  Take  Pre-instruction  Exception  format 


/.  Take  Mid-Instruction  Exception 

The  MC6888 1  uses  this  primitive,  if  an  exception  occurs  during  the  execution  of 
FMOVE  FPm,  <ea>  instruction.  In  the  format  of  this  primitive,  the  CA,  PC  and  DR 
bits  are  set  to  zero.  Bits  0  through  7  contain  the  vector  number  which  identifies  the 
type  of  exception.  Bit  9  is  zero,  and  all  the  other  bits  are  ones  (Figure  60). 


f  PC  *  t  1  I  I  I 


VECTOR  NUHRCR 


Figure  60  Take  Mid-instruction  Exception  format 
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APPENDIX  G:  DESIGN  OF  THE  ECB 


A.  Memory  Mapping 

The  memory  is  divided  into  three  segments: 

-  First  segment  :  $00000  -  $1FFFF 

-  Second  segment  :  $20000  -  $3FFFF 

-  Third  segment  :  $40000  -  $7FFFF 

There  are  two  memory  mapping  schemes  which  differ  from  each  other  in  how 
the  segments  are  accessed.  The  first  scheme  is  defaulted  after  reset  or  power-up.  The 
only  way  to  switch  from  the  first  scheme  to  the  second  is  to  make  a  coprocessor 
access.  An  external  reset  should  be  applied  in  order  to  switch  back  to  the  first  scheme. 

The  memory  map  in  scheme  1  is  shown  in  Table  16. 


Table  16  ECB  Memory  Mapping  Scheme 
1. 


AOOKCSS  RANGE 

READ 

IRIIE 

SCCUENI  1 

•  lirrrrr 

ROW 

RAH 

SCCaCNT  2 

-  UrrrFr 

COP 

COP 

scemm  j 

-  prrrrr 

RON 

In  scheme  1,  both  ROM  and  RAM  are  mapped  to  Segment  1.  RAM  is  accessed  for 
writing  only  and  all  reads  are  from  ROM.  Segment  2  can  be  accessed  for  both  writing 
and  reading.  ROM  can  also  be  accessed  in  the  higher  addresses.  The  primary  area  for 
ROM  is  Segment  3.  The  ROM  in  the  low  addresses  can  be  thought  as  an  image  of  the 
ROM  in  the  high  addresses.  This  image  is  created  and  removed  by  the  signal,  called 
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PHANTOM.  Mapping  the  ROM  to  Segment  1  allows  to  access  the  initialization 
routines  after  reset  or  power-up. 


The  memory  map  in  scheme  2  is  given  in  Table  17. 


Table  17  ECB  Memory  Mapping 
Scheme  2 


AOORtSS  RANC£ 

secucNT  1 

-  tiFrrrr 

RAM 

SeCHCNI  2 

(2*»*«  -  tiFrrrr 

COP 

SCCUCNI  i 

•  t’FFFrr 

ROM 

In  the  second  scheme,  the  image  of  ROM  is  removed  from  Segment  1.  RAM  can  be 
accessed  for  both  reading  and  writing.  This  is  the  condition  in  normal  operation  of  the 
ECB. 


B.  Programmable  Array  Logic  circuit  PAL  B 

Figure  61  shows  how  the  chip  select  and  other  control  signals  are  generated  for 
the  memory  mapping  schemes.  All  the  signals  are  the  outputs  of  the  PAL  B 
(PAL16L8).  This  PAL  has  been  programmed  by  ABEL  software.  Appendix  H  includes 
the  programming  files  of  the  PAL  B. 
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Figure  61  Generation  of  the  memory  mapping  signals 


C.  Programmable  Array  Logic  Circuit  PAL  A 


The  PAL  A  generates  the  signals  required  for  interfacing  the  MC68020  with 
memory  and  RS-232  port. 


1.  The  PHANTOM  Signal 


The  PHANTOM  signal  is  used  to  create  and  remove  an  image  of  the  ROM  in 
Segment  1.  During  power-up  or  reset,  asserting  the  IRESET  line  sets  the  PHANTOM 
output  high.  This  output  remains  high  after  the  IRESET  input  is  negated,  until  a 


coprocessor  access  occurs,  i.e.,  the  ICopE  input  is  asserted.  It  is  the  responsibility  of 
initalization  routine  to  assert  the  ICopE  input  by  making  an  access  to  Segment  2.  (see 
Reference  1).  The  ICopE  input  is  synchronized  with  the  IAS  signal. 


4 


Figure  62  PHANTOM  signal  generation. 


I 

2.  RS232  Transmit/Receive  Circuit 

The  lINTERRUPT  output,  which  is  connected  to  the  1IPL2  input  of  the 
MC68020,  indicates  that  data  is  being  received  on  ^-232  line.  The  lINTERRUPT 
output  is  not  asserted,  unless  the  address  lines  A19  and  A17  are  set  high,  even  if  there 
is  an  incoming  data  on  RS-232  line.  It  is  the  responsibility  of  the  communication 
routine  to  monitor  the  RS-232  line  by  setting  the  address  lines  A19  and  A17.  (see 
Reference  1  ). 
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The  IRS2320UT  output  is  used  to  transmit  data  on  RS-232  line,  by  asserting  and 


negating  the  address  lines  A19  and  A15  under  software  control.  (See  Reference  1.) 


Figure  63  RS232  Transmit/Receive  Circuit 


( 

3.  Data  Size  And  Transfer  Acknowledge  S^als 

The  DSACK  signals  return  8-bit  port  size  for  the  ROM,  and  32-bit  port  size  for 
the  RAM.  A^\  access  to  the  coprocessor  does  not  cause  the  DSACK  signals  to  be 
asserted,  as  the  MC6888 1  provides  its  own  pent  size.  If  the  ROM  is  accessed,  only  the 
DSACKO  output  is  asserted  to  return  an  8-bit  port  size.  The  outputs  WO,  W1  and  W2 
are  used  to  provide  a  delay  of  eight  clock  cycles,  before  asserting  the  DSACKO,  when 
the  ROM  is  accessed.  This  is  because  the  ROM  chip  has  a  longer  delay  (150  ns  for 
AMD  27C256  chip)  than  the  RAM  chips  (55  ns  for  Motorola  6164  chip).  Both 
DSACK  signals  are  asserted,  without  any  forced  delay,  when  the  RAM  is  accessed. 
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Figure  64  DSACK  Signal  Generation. 
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D.  Reset  Circuit 


The  reset  circuit  was  built  around  the  Motorola’s  undervoltage-sensing  IC,  the 
MC34064.  The  output  of  the  circuit  is  driven  low  for  more  than  100  ms,  during  power- 
up  or  when  the  reset  button  is  pressed,  and  provides  an  external  reset  signal  for  both 
the  MC68020  and  MC6888 1. 


E.  Software  Abort  Circuit 

The  circuit  for  software  abort  consists  of  all  passive  components,  as  shown  in  the 
following  figure.  When  the  switch  SI  is  pressed,  IPL2,  IPLl  and  AVEC  lines  are  held 
low  for  a  period  of  approximately  5  microsecond,  which  generates  an  autovectored 
level  6  interrupt. 
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Figure  66  Software  Abort  circuit 


F.  I/O  Interface  for  External  Devices 

I 

All  the  pads  and  holes  have  been  provided  to  install  TTL  series  line  drivers 
74245  (bidirectional  for  8-bit  data)  and  74244/74241  (unidirectional  for  address  and 
control  lines).  The  connections  for  external  I/O  interface  are  given  in  Figure  67.  This 
interface  has  not  been  implemented  and  tested  in  this  thesis.  It  is  left  as  a  future 
improvement. 
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Figure  67  I/O  interface  for  external  devices 


The  complete  circuit  diagram  and  two  layer  PCB  layout  are  given  in  figures  68 
and  69,  respectively.  The  I/O  interface  for  external  devices  are  not  included  in  the 
circuit  diagram. 
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Figure  68  ECB  Circuit  Diagram. 


APPENDIX  H:  PAL  A  PROGRAMMING  FILES 


A.  PAL  A  USmNG  FILE 


0001  hnodule  palal  ; 

0002  (flag  ’-f  : 

0003  I  PAL  A  DEVICE  ’P1<5R4’; 

0004  \  CLk;COPE4lESETA19^17A15^SJlSIN  PIN  1.7^3^, 9, 6.4 

0005  1  RAMCB.OE4*HANJlSOUTJNT  PIN  8.11,17.18,19 

0006 1  W0,W1,W2J)SACK0J)SACK1  PIN  16.15,14,13.12 

0007  1  CK.X.Z  =  .C.JC.,.Z. 

0008  I 

0009  I  SO  =  ''BOOO  : 

0010  I  SI  =  ''BOOl  : 

001 1  I  S2  s  '^BOIO  ; 

00121  S3  =  '^B011; 

0013  I  S4  *  ''BlOO  ; 

0014  I  SS  =>  ABlOl  ; 

0015  1  SOa'^BllO; 

0016  1  S7*abiii; 

0017  I 
0018  I 

0019  tTEST  VECTORS  (  (CLK,OEJlAMCE.AS.COPE]  ->  rW0,Wl,W2J>SACK0I) 
0020 1  ” 

0021  I 
0022  I 
0023  I 
0024  I 
00251 
0026  I 
00271 
0028  I 
0029  I 
00301 
0031 1 
0032  I 
0033  I 
0034  I 
0035  I 
00361 
0037  I 
0038  I 
0039  I 
0040  I 
0041  I 
0042  I 
0043  I 
0044  I 
0045  I 
0046  I 
0047  I 
0048  I 

0049  rreST  VECTORS  (  [CLK,OEAS,COPE41ESEr4»HANl  ->  [PHAN] ) 


00501 

(CK.0.0.1.0.0] 

->  [IJ 

0051  1 

[CK,0.0.1,0.1] 

■>  11] 

0052  1 

(CK.0.0,1.0,1J 

->  Ill 

0053  1 

[CK.0,0.1,1,1] 

->  [1] 

0054  1 

[CK.0.0. 1.1.1] 

->  [I] 

0055  1 

[CK.0.0,1,1,1] 

->  [1] 

00561 

(CK.0.0, 1.1,1] 

->  11] 

0057  1 

[CK,0.0.I.1.1] 

■>  [1] 

0058  1 

[CK.0.0.1.1,J] 

->  [1] 

0059  1 

[CK.0,0,1.1.1] 

->  [1] 

tCK.0.1.1.0 
(CK.0.1.0.0 
[CK.0.1,0.0 
[CK.0,1A0] 
[CK.0.1.0.0 
(CK.0.1,0.0j 
[CK,0.1.0.0 
[CK.0.1.0.0 
[CK,0. 1,0,0 
[CK.0.1.0.0 
[CK,0.0,0,0 
[CK.0.1.1.0: 
[CK.1.1.1.0: 

[CK.0.1,1,11 
[CK.0.1.0.1] 
[CK,0.1.0.1] 
[CK.0.1,0.1J 
[CK,0.1.0.1] 
[CK.0.1,0,1] 
(CK.0.1.0.1] 
[CK,0.1,0.1] 
[CK.0,1.0,1] 
[CK.0,1.0.!] 
[CK,0.0.0,1] 
[CK.O.l.l.l] 
[CK.1, 1,1,1] 


->  10.0,0,1] 
•>  H.1.1.1 
->  [O.l.l.l 
->  11.0,1,1 
■>  [O.O.l.l 
->  (1.1.0.I 
->  [0.1.0.1 
->  [1.0.0.1 
->  [1, 0,0,1 
->  [1.0.0.1 
->  [1.0.0.1 
->  [O.O.O.l 
->  [ZZ.Z.1] 


->  [0.0, 0.1] 
->  [1.1.1.1J 
->  [0,1, 1.1] 
->  [l.O.l.l] 
->  (0.0.1.1] 
->  [1.1.0.1] 
->  [0,1. 0,1] 
->  [1.0.0.0] 
->  [1,0.0.0] 
->  [1,00.0] 
->  [1.0 ,0.0] 
->  [0.0,0,1] 
->  [Z.Z.Z,1] 


100 


0060  1 

[CK,0.0.1.1.1] 

->  [1] : 

0061  1 

tCK.0,0, 1.1.1] 

->  [11: 

00621 

ICK,0.0. 1,0,1] 

->  [1]  : 

0063  1 

[CK.0.0.1.0.1] 

->  [11: 

0064  1 

ICK,0.0.1.0,1] 

->  [1] : 

0065  1 

ICK.0.0.0.0.1] 

->  [Oj: 

00661 

[CK,0.0, 1,0,0] 

->  [1] : 

0067  1 

[CK,0.0.1,1.1] 

->  [1]  ; 

0068  t 

[CK.0.0,1.1.1] 

->  [1]; 

00691 

ICK,0,0.0.1,1] 

->  [OJ; 

00701 

ICK.0,0,0.1,0J 

->  [0] : 

0071  1 

tCK.0.0,1,1.0] 

->  [01; 

0072  1 

[CK.0,0.1,1.0] 

->  [01: 

0073  1 

[CK,0.0,1,0,0] 

->  [11; 

00741 

0075  1 

[CK,0,0,1.0,1] 

->  [11: 

00761 

tCX,0,l,1.0.0] 

-> 

n 

0077  1 

ICK,0.1,1.0.1] 

-> 

n 

0078  1 

ICK,0.1.1.0.1] 

-> 

n 

00791 

[CK.0.1.1.1,1] 

-> 

n 

00801 

tCK,0.1,l.l.l] 

-> 

n 

0081  1 

[CK.0.1.1,1.1] 

-> 

11 

0082  1 

[CK,0.1,1.1,11 

-> 

u 

0083  1 

tCK.0.1.1,1.1] 

-> 

1] 

0084  1 

tCK.0,1.1,1.1] 

-> 

11 

0085  1 

[CIC,0.1.1.1.1] 

-> 

11 

00861 

[CK.0.1.1.1.1] 

.> 

1] 

0087  1 

[OCO.l.l.l.l] 

-> 

11 

0088  1 

ICK,0,1,1,0.1] 

-> 

1] 

00891 

[CK,0.1.1.0.1] 

-> 

n 

0090  1 

ICK.0.1.1.0.11 

-> 

11 

0091  1 

tCK.0.1.0.0.1] 

-> 

n 

00921 

ICK.0.1.1.0.0] 

-> 

11 

0093  1 

ICK,0.1.1,1.1] 

-> 

n 

0094  1 

tCK.0.1.1.1,1] 

-> 

u 

0095  1 

00961 

(CK,0.1.0.1.1] 

-> 

[ij 

0097  1 

[CK.0.1.0,1.1] 

-> 

n 

0098  1 

[CK,0.0,0.1.0J 

-> 

O) 

00991 

[CK.0,1,0,1.0] 

-> 

PI 

0100  1 

ICK.0.1,1.1.0] 

-> 

PI 

0101  1 

0102  1 

ICK.0.1.1.0,0] 

-> 

[11 

0103  1 

0104  1 

ICK.0.1.1.0.1] 

-> 

[11 

0105  ITEST.VECrORS  (  IA19  ,  A15J  ->  [RSOUTI  ) 


01061 

[0.01 

-> 

[1] 

0107  1 

[0.1] 

-> 

[1] 

0108  1 

[1.0] 

-> 

[1] 

0109  1 

01101 

[1.1] 

-> 

[0] 

Olli  ITEST_VBCrORS  (  [A19  ,  A17,  RSIN] ->  [INT]  ) 


01121 

[0.0.0] 

-> 

[11; 

0113  1 

[0.0.1] 

-> 

[11; 

0114  1 

[0.1.0] 

-> 

[11: 

0115  1 

[0.1.1] 

-> 

[11: 

01161 

[1.0.0] 

-> 

[11: 

0117  1 

[1.0.1] 

-> 

in ; 

0118  1 

[1.1.0] 

-> 

[0]: 

01191 

01201 

[U.'l 

-> 

[1]; 

0121  ITEST_VECrORS  (  (AS,  W0.W1,W2JIAMCE.CX)PE]  ->  {DSACKOJ  ) 


0122  1 

[0.0.0.0.0,11 

->  [01 : 

0123  1 

[0.1.0.0.X.1] 

->  [01: 

0124  1 

[1.X.XJCA1] 

->  [1] 

0125  1 

I1.X.X.XX11 

->  [11 

0126  1 

0127  1 

0128  1 

[X.XJCAX.0] 

^  [11 

101 


0129  ITEST_VECrORS  (  [AS.  A15,  COPE,  RAMCE]  ->  O^SACKl]  ) 


01301 

[0, 0.0,0] 

-> 

01 

0131  1 

(0.0,0.1 

-> 

11 

01321 

10.0.1.0 

-> 

01 

0133  1 

[0.0.1,1 

-> 

11 

01341 

[0.1.0.0 

-> 

01 

0133  1 

10.1,0.1 

-> 

01 

01361 

[0.1.1.0 

-> 

01 

01371 

10.1.1.1 

-> 

11 

0138  1 

[1.0.0.0 

-> 

11 

01391 

[I.0.0,1 

-> 

11 

01401 

[1.0.1,0 

-> 

11 

0141 1 

[1.0.1.1 

-> 

n 

01421 

[1.1.0.0 

-> 

11 

0143  1 

[U.0.1 

-> 

11 

0144  1 

11.1.1,0 

-> 

n 

0145  1 

[1.1.1.1] 

-> 

[11 

01461 

01471 

0148  (EQUATIONS 

0149 1  RSOUT  » I  (A19  A  A13)  ; 

0150 1  INT  =  I  (A19  A  A17  A  IRSIN)  ; 

0131  I  DSACKO  =  AS  «  (  RAMCE  &  (I  WO  «  W1  #  W2  )  )  «  (COPE  ; 

0132  t  IDSACKl  »  (  IAS  ft  (RAMCE  )  #  (  IAS  ft  (COPE  ft  A15  ) 

0133  I  (PHAN  (((COPE  #  AS))  #  (RESET  ft  (PHAN) 

0154  I  1W2  :=  AS  #  (  WO  ft  IWl  ft  IW2  )  #  (  (WO  ft  IWl  ft  W2  )  #  (  W1  ft  IW2  ) 

0155  I  IWl  :«  AS  #  (  (WO  ft  W1  )  #  (  WO  ft  (Wl  )  ; 

0156  I  (WO  ;=  AS  #  (  WO  ft  Wl  )  #  (  WO  ft  W2  ) 

0137  I 

0158  lend  palal 
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ABEL(tm)  3.00a  -  Document  Oeneiator  26-Jul-89  05:21  PM 

Symbol  list  for  Module  palal 


AIS 

Pin  9  poa,  com 

A17 

Pin  5  poa,  com 

A19 

■  Pin  3  poa,  com 

AS 

Pin  6  poa,  com 

CK 

(.C.) 

CLK 

Pin  1  poa,  com 

COPE 

Pin  7  poa,  com 

DSACKO 

Pin  13  neg,  com 

DSACKl 

Pin  12  neg,  com 

INT 

Pin  19  neg,  com 

OE 

Pin  11  poa,  com 

PAL  A 

device  P16R4 

PHAN 

Pin  17  neg,  reg,  D 

RAMCE 

Pin  8  poa,  com 

RESET 

Pin  2  poa,  com 

RSIN 

Pin  4  TOa,  com 

RSOUT 

Pin  18  neg,  com 

SO 

(0) 

SI 

U) 

S2 

(2) 

S3 

(3) 

S4 

(4) 

S5 

(5) 

S6 

(6) 

S7 

(7) 

WO 

Pin  16  neg,  reg,  D 

W1 

Pin  IS  neg,  leg,  D 

W2 

Pin  14  neg,  reg,  D 

X 

(.X.) 

z 

(.Z.) 

PHAN  QN 

Node  24  poa,  com 

"wo  QN 

Node  23  poa,  coni 

"Wl  QN 

Node  22  poa,  com 

_W2_QN 

Node  21  poa,  com 

palal 

Module  Name 
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Equationi  for  Module  palal 

Device  PAL_A 


Page  2 

25-;ul-89  0S:21  PM 


-  Reduced  Equations: 

RSOUT  =  I(A15  «  A19): 

INT  =  l(A17  &  A19  &  IRSIN): 

DSACKO  =  t(IAS  &  COPE  A  WO  A  (W1  A  IW2  #  »AS  A  COPE  A  IRAMCE); 
DSACKl  I(A1S  A  IAS  A  ICOPE  #  IAS  A  IRAMCE); 

PHAN  ;=  KIPHAN  A  RESET  #  IAS  A  ICOPE); 

W2  :=  I(W1  A  IW2  #  IWO  A  IWl  A  W2  #  WO  A  IWl  A  IW2  #  AS); 

W1  ;=  l(W0  A  IWl  #  IWO  A  W1  #  AS); 

WO  ;=  l(W0  A  W2  #  WO  A  W1  #  AS); 
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Page  3 

ABELCtm)  3.00a  -  Document  Oenentor  26-M-89  05:21  PM 

CSiip  diagnun  for  Module  palal 

Device  PAL_A 
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ABEL(tm)  3.00a  -  Document  Oeneiator 
Fuse  Map  for  Module  palal 

Device  PAL_A 


Page  4 

26-Jut-89  0S:21  PM 


0  10  20  30 

32:  —X—X  -X - 

256: - 

288:  — X- - X-  - 

512:  X - X - 

544: - X-  -X - 

768: - X- - X- - 

800: - X -X - 

832: - -X - 

1024: - X — X - 

1056: - X-X - 

1088: - -X - 

1280: - X-  — X- - 

1312; - X—X  -X - 

1344: - X—X  -X - 

1376; - -X - 

I5S1  Z_“  Sx  -X  X  X-  X - 

1600: - X-  X—X - 

1792; - 

1824: - X-  -X— --X-  - 

1836;  - — — - — X—  - — X- —  — 
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ABEL(lni)  3.00a  -  Document  Generator  26-Jul-89  05:21  PM 

for  Module  palal 

Device  PAL_A 


Device  Type;  P16R4  Terms  Used:  22  out  64 


Pin  #  1  Name 

Terms 

1  Used  1 

Max  1  Term  Type  1  Pin  Type 

1 

1  CLK 

1  -  1 

-  1  —  1  Qock 

2 

1  RESET 

1  -  1 

-  1  —  1  Input 

3 

1  A19 

1  -  1 

-  1  —  1  Liput 

4 

1  RSIN 

1  -  1 

—  1  —  1  Input 

5 

1  A17 

1  -  1 

--  1  —  1  Input 

6 

1  AS 

1  -  1  ■ 

-  1  —  1  Input 

7 

1  CX)PE 

1  -  1 

—  1  —  1  Input 

8 

1  RAMCE 

1  -  1 

--  1  —  1  bput 

9 

1  A15 

1  -  1 

-  1  —  1  Input 

10 

1  OND 

1  -  1 

-  1  —  lOND 

11 

1  OE 

1  -  1 

-  1  —  1  Enable 

12 

1  DSACKl 

1  2 

1  7  INomial  11/0 

13 

1  DSACKO 

1  2 

1  7  1  Normal  t  I/O 

14 

1  W2 

1  4  1 

8  1  Normal  1  Output 

15 

1  W1 

1  3  1 

8  1  Normal  t  Output 

16 

1  WO 

1  3  1 

8  1  Normal  1  Output 

17 

1  PHAN 

1  2  1 

8  1  Normal  1  Output 

18 

t  RSOUT 

1  1  1 

7  (Normal  (I/O 

19 

1 INT 

1  1  1 

7  1  Normal  1  I/O 

20 

1  Vcc 

1  -  1 

-  1  —  IVCC 

21 

(  W2  QN 

1  -  i 

1  -  1  —  1  Input  (node) 

22 

1  W1  QN 

'1  - 

1  —  1  —  1  Input  (node) 

23 

1  WO  QN 

1  - 

1  -  1  —  1  Ii^Hit  (node) 

24 

1  PHAN  QN 

1  ~ 

1  —  1  —  1  Input  (node) 
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C—  -101  --0- 
C—  4)01  -4)- 
C—  4)01  -4)- 
C—  4)01  -4)- 
C—  4)01  -4)- 
C—  4)01  -4). 
C—  4)01  -4)- 
C—  4)01  -0- 
C—  4)01  -4)- 
iC—  4)01  -4)- 
[C—  4)00  -4)- 
[C—  -101  --0- 
IC—  -101  -1- 
[C—  -111  -4)- 
[C--  4)1 1  -4)- 
|C—  -oil  --0- 
[C—  4)11  --0- 
[C--  4)11  -4)- 
[C—  4)11  --0- 
[C—  4)11  -4)- 
[C--  4)1 1  -4)- 
[C—  -Oil  -4)- 
[C—  -Oil  -4)- 
[C—  4)10  -4)- 


- )  ->  I- 

- ]  ->  l- 

- 1  ->  (- 

- j  ->  I- 

- ]  ->  [- 

- 1  ->  [  - 

- )  ->  l- 


- J  -> 

- ]  ->  I- 

- ]  .>  [-. 

- 1  ->  r- 

. 1  ->  l  - 

- J  ->  I-. 

- 1  ->  1-- 

- 1  ->  (- 

- ]  ->  [- 

- . I  ->  (  - 


- 1  ->  l- 

- ]  ->  [- 

—  — j  -> 

- ]  -> 


25 

IC—  -111-0- 

->l 

.... 

.... 

HLLL  — 

26 

(C—  -111  -1- 

«... 

->  1 

.... 

.... 

HZZZ  — 

27 

{CO-  -Ol-  -4)- 

-> 

— 

— 

.... 

.... 

H— 

28 

ICX)-  -0{-  -0- 

— 

— 

H— 

29 

(CO-  -01-  -4)- 

-> 

-- 

.... 

M.« 

H— 

30 

(Cl-  -01-  -0- 

-> 

... 

.... 

.... 

H— 

31 

(Cl-  -01-  -4)- 

-> 

.... 

— 

H- 

32 

(Cl-  -01-  -4)- 

-> 

— 

.... 

— 

H- 

33 

(Cl-  -01-  -0- 

1-.- - 

v> 

.... 

— 

- - 

H- 

34 

(Cl-  -01-  -4)- 

1 - 

-> 

— 

— 

.... 

- - 

H— 

35 

(Cl-  -01-  -4)- 

I—.  — 

-> 

-- 

. — 

— 

H- 

36 

(Cl-  4)1-  -0- 

1 - 

-> 

— 

— 

— 

H— 

37 

(Cl-  4)1-  -4)- 

— — 

i - 

-> 

-- 

— 

— 

H- 

38 

(Cl-  -01-  -4)- 

1 —  — 

-> 

— 

— 

— 

H- 

39 

(CO-  -01-  -4)- 

1 - 

-> 

— 

— 

— 

H— 

40 

(CO-  -01-  -0- 

— 

1 - 

-> 

— 

— 

— 

H- 

41 

(CO-  -01-  -4)- 

-> 

— 

.... 

H— 

42 

(CO-  -00-  -0- 

-> 

— 

— 

— 

43 

(CO-  -01-  -4)- 

0 - 

-> 

-- 

— 

— 

— 

H— 

44 

(Ci-  -01-  -4)- 

1 - 

-> 

-- 

— 

— 

— 

H— 

45 

(Cl-  -01-  -0- 

1 —  — 

-> 

— 

— 

H— 

46 

(Ct-  -00-  -4)- 

1 - 

-> 

— 

.... 

.... 

— 

L— 

47 

(Cl-  4)0-  -0- 

0 - 

-> 

— 

..... 

.... 

L~ 

48 

(Cl-  -01-  -0- 

... 

0 - 

-> 

— 

.... 

— 

L— 

49 

(Cl-  -01-  -4)- 

0 - 

-> 

— 

.... 

— 

L~ 

50 

(CO-  -01-  -4)- 

— 

0 - 

-> 

— 

— 

— 

H- 

51 

(CO-  -01-  -4). 

— 

1 - 

-> 

[— 

— 

— 

— 

H— 

HULL - 1; 

HHHH - 1; 

HHHL - 1: 

HHLH - ]; 

HHLL - ]; 

HLHH - J; 

HLHL - ]; 

HLLH - J; 

HLLH - ); 

HLLH - 1: 

HLLH - J: 

HLLL - -J; 

HZ2Z - J; 

HLLL - 1; 

HHHH - J; 

HHW _ 1: 

HHLH - ]; 

HHLL - J; 

HLHH - ); 

HLHL - ]: 

lllh - 1: 

LLLH - ]; 

lllh - 1; 

lllh - J; 
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Test  Vecton  for  Module  palal 


Device  PAL_A 


104 

- 101  0- - 1  -> 

- H - ^1 

105 

- 110  0- - ]-> 

- — H  — - J 

106 

- Ill  0 - 1  -> 

- H - - 1 

107 

- 100  1 - ]  -> 

—  —  — H - ] 

108 

- 101  1 - -]  -> 

— - H  —  —  — ] 

109 

- 110  1 - ]  -> 

^  — —  — -  ”J 

110 

- Ill  1 - -]  -> 

end  of  module  palal 
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APPENDIX  1 :  PAL  B  PROGRAMMING  FILES 


A.  PAL  B  LISTING  FILE 


0001  hnodule  palb  ; 

0002  Iflag  ’-r  ; 

0003  ) 

0004  r  MONOLITHIC  MEMORIES  INC.  PAL  16L8A-4  FAMILY/PINOirr  CODE  :  22/17 
0003  r  NATIONAL  SEMICONDUCTOR  PAL  16L8A2  FAMJLY/PJNOUT  CODE  :  93/17 
00061 

0007  I  PAL  B  DEVICE  ’P16U': 

0008  I  RWX>S.Sl.S0A0>LlJ»>V18.A17.aND  PIN  1^3.4.5,6,7,8.9,10  ; 

0009  1  A15.ROMCE,RAMlWJlAM2WJlAM3W,RAMCE  PIN  11,12,13,14,15,16  ; 

0010 1  RAM4W,COPEJ1AMOE.VCC  PIN  17,18,19,20  ; 

0011  I  H,L,X  »  1,0,.X. 

0012  I 
0013  I 

0014  I  EQUATIONS 

0015  I  IRAMCE  =  (IRW  APA  IDS)  #  (  IA18  A  IA17  A  !P  A  (DS  )  ; 

0016  I 

0017  I  IRAMIW  =  (  IA18  A  IA17  A  IRW  A  lAl  A  lAO  A  IDS  ); 

0018  I 

0019  I  IRAM2W  =  (  IA18  A  !AI7  A  IRW  A  lAl  A  ISO  A  IDS  ) 

0020  I  #  (  IA18  A  IA17  A  IRW  A  lAl  A  AO  A  IDS  ) 

0021  I  #  (  IA18  A  IA17  A  IRW  A  lAl  A  SI  A  IDS  ); 

0022  I 

0023  I  IPJVM3W  =  (  IA18  A  IA17  A  IRW  A  A1  A  lAO  A  IDS  ) 

0024  I  #  (  IA18  A  IA17  A  IRW  A  lAl  A  ISl  A  ISO  A  IDS  ) 

0023  I  «  (  IA18  A  IA17  A  IRW  A  lAl  A  SI  A  SO  A  IDS  ) 

0026  I  #  (  IA18  A  IA17  A  IRW  A  lAl  A  AO  A  ISO  A  IDS  ); 

0027  I 

0028  I  IRAM4W  =  (  IA18  A  IA17  A  IRW  A  SO  A  SI  A  AO  A  IDS  ) 

0029  I  #  (  IA18  A  1A17  A  IRW  A  ISl  A  ISO  A  IDS  ) 

0030  I  #  (  IA18  A  IA17  A  IRW  A  A1  A  AO  A  IDS  ) 

0031  I  #  (  IA18  A  IA17  A  IRW  A  A1  A  SI  A  IDS  ); 

0032  I 

0033  I  IROMCE  =  (IA17  A  RW  A  P  A  IDS  )  #  (A18  A  RW  A  IP  A  IDS  )  ; 

0034  I 

0035  I  IRAMOE  =  (IA18  A  IA17  A  RW  A  IP)  ; 

0036  I 

0037  I  ICOPE  =  (IA18  A  A17  A  IA15) 

0038  I 

0039  lte»t_vector»  (  [A18,A17,A15JlW4>wM.AO.Sl,SO.DS]  -> 

0040 1  [RAMCE.RAM1W41AM2W41AM3W4LAM4W410MCE41AM0E,C0PE)) 

0041  I 

0042  I  'RAMCE 

0043  I  [X,XX.L.H,X,X,X,X,L]  ->  [L.X,X,X,X,X,X,X]  ; 

0044 1  ILJLXX.L,X.XAX4-]  ->  ILJC.X,X,XXXX]  ; 

0043  rRAMlW 

0046 1  [L,L.X4-.Xa.a..X,XW  ->  IX,L,X,X,X,X,X.X)  ; 

0047  rRAM2W 

0048  I  {LJL.XJL,XJ.XXi4.J  ->  (X,Xi,X,X,X,X,XJ 

0049  I  [LX,XJLX4-,H,X,X4-]  ->  [XX.L.XX.X,Xjq 

0050 1  [LX.XX.X4.AH,XX]  ->  IX,X,L.X,X,X,X,XJ  ; 

0051  rRAM3W 

0052 1  [LX.XX.XH.L,XJtXJ  ->  [X,X,XX.X,X.X,X]  ; 

0053 1  |L.L,XX.XX.X,LX.L1  ->  tX,X,X.L.X,X,X.XJ  ; 

0054  I  (LX,XX.XXJC.HHX]  ->  {XJC.XX.X,XJC,XJ 

0053 1  ILX.XXALH.XXX]  ->  [XHH.LHAXHl  : 

0036  rRAM4W 

0057 1  [LX,XX.XAHiIHX]  ->  [X,X.X,XX.X.XA  : 

0058 1  (LXJCX.XJC.XXXXI  ->  [XAX,XX.XAXJ  ; 

0059 1  ILXJCXAH.HJC,XXJ  ->  IXAXAL,X.XA  ; 

0060 1  (LXAL,XH.XHJCX]  ->  (XAX,XX.X,XH]  : 

0061  rROMCE 

0062 1  [XXAHH.X,X,XAL]  ->  PC.XAX.XX.XJC]  ; 
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0063  I  tH.XAm-^AX;K.LJ  -> 

0064  TRAMOB 

0065  I  lLJLXH4-AX^ra  ->  pCAX^^Wq 

0066rCOPE 

0067  I  ILAL.X.X^^^^  ->  tX^AX^ALJ 

0068  I 

00691 

00701 

0071  lend 
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Page  1 

ABEL(tm)  Venion  2.00b  -  Document  Qenentor  03-Kiay-89  11:11  AM 

Bquationf  foi  Module  palb 

Device  PAL_B 


Reduced  Equatlona: 

RAMCE  »  KIDS  &PA  IRW  #  IA17  A  lAlS  A  IDS  A  IP); 

RAMIW  =  l(IA0  &  lAl  A  IA17  A  IA18  A  IDS  A  IRW); 

RAM2W  =  l(A0  A  lAl  A  IA17  A  IA18  A  IDS  A  IRW 
#  lAl  A  IA17  A  IA18  A  IDS  &  IRW  A  ISO 
«  lAl  A  IA17  A  IA18  A  IDS  A  IRW  A  SI); 


RAM3W  =  l(IA0  &  A1  &  IA17  A  IA18  A  IDS  A  IRW 
«  AO  &  lAl  &  IA17  A  IA18  A  IDS  A  IRW  &  ISO 

#  lAl  &  IA17  &  IA18  A  IDS  &  IRW  A  ISO  &  ISl 

#  lAl  A  IA17  A  IA18  A  IDS  A  IRW  A  SO  A  SI); 


RAM4W  =  l(A0  &  A1  &  IA17  &  IA18  A  IDS  A  IRW 

#  A1  &  IA17  A  IA18  A  IDS  A  IRW  A  SI 

#  IA17  A  IA18  A  IDS  A  IRW  A  ISO  A  ISl 

«  AO  A  IA17  A  IA18  A  IDS  &  IRW  A  SO  &  SI); 


ROMCE  =  l(IA17  A  IDS  A  P  A  RW  #  A18  A  IDS  A  IP  A  RW); 
RAMOE  =  l(IA17  A  IA18  A  IP  A  RW); 

COPE  =  KIA15  A  A17  A  IA18); 
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ABEL(tin)  Venion  2.00b  -  Document  Oeneretor 
C3iip  (Uagiam  for  Module  palb 

Device  PAL_B 


P16L8 


1 

/  1 

1 

RWI  1 

20  IVCC 

1 

1 

DS  1  2 

19  1  RAMOE 

1 

1 

SI  1  3 

18  ICOPE 

t 

1 

SO  1  4 

17  IRAM4W 

1 

1 

AOI  5 

16  IRAMCE 

1 

1 

A1  1  6 

1 

15  1  RAM3W 

1 

PI  7 

14  1  RAM2W 

1 

1 

A18  1  8 

13  IRAMIW 

1 

1 

A17  1  9 

12  IROMCE 

1 

1 

ONDI  10 

11  IA15 

I 

1 


Page  2 

03-May-89  11:11  AM 
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Page  3 

ABEL(tin)  Venion  2.00b  -  Document  Generator  03-May-89  11:11  AM 

Fuse  Map  for  Module  palb 

Device  PAL_B 

0  10  20  30 

32:  -X - X— X— X  - 

64:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
96:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
128;  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
160:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
192:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
224;  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 

236: - 

288: - X-X-  -X 

320;  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
332:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
384:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
416;  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
448:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
480;  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 

312: - 

344:  -X-X - X— X - -X— X  - 

376:  -X-XX- - X - X— X  - 

608:  -X-X-X— X - -X— X  - 

640:  -X-XX --X-  -X - X~X  - 

672:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
704:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
736;  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 

800:  -X-.X - X - 

832;  -X - X~X— X  - 

864:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
896;  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
928:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
960:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
992:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 

1024: - 

1036:  -X-X- - X-X - -X— X  - 

1088:  -X-X - X  ~X — X - X~X  - 

1120:  -X-X-X— X - X - X— X  - 

1132:  -X-XX~X- - X - X~X  -- 

1184;  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1216:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1248:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 

1280: - 

1312:  -X-X - X~ X - X— X  - 

1344:  -X-X - X - -X- - X—X  - 

1376:  -X-XX - X- - X—X  - 

1408:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1440:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1472:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1304;  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 

1336: - 

1568:  -X-X - X—X- - X—X  - 

1600:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
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Page  4 

ABEL(tm)  Version  2.00b  -  Document  Generator  03>May-89  11:11  AM 

Fn*e  Map  for  Module  palb 

Device  PAL_B 

1632:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1664:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1696:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1728:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1760:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 

1792: - 

1824:  -XX - X - ^X  - 

1856:  -XX - -X-X - 

1888:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1920:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1952:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
1984:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
2016:  XXXXXXXXXX  XXXXXXXXXX  XXXXXXXXXX  XX 
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r 


Device  Type:  P16L8 


Terms  Used:  26  out  of  64 


Pin  «  I  Name 


Terms 

I  Used  I  Max  I  Term  Type  I  Pin  Type 


1  I RW 

2  IDS 

3  I  SI 

4  I  SO 

5  I  AO 

6  I  A1 

7  I  P 

8  I A18 

9  I  A17 

10  I OND 

11  I  AIS 

12  I  ROMCE 

13  I RAMIW 

14  I  RAM2W 

15  I RAM3W 

16  I RAMCE 

17  I  RAM4W 

18  I  COPE 

19  IRAMOE 

20  I VCC 


I  -  I  - 

l  -  I  - 

I  -  I  - 

l  -  I  - 

I  -  I  - 

I  -  I  - 

I  -  I  - 

l  -  I  - 

I  --  I  - 

l  -  I  - 

I  -  I  - 

I  2  I 

I  1  I 

I  3  I 

I  4  I 

I  2  I 

I  4  I 

I  1  I 
I  1  I 

I  -  I  - 


I  —  I  Ii^ut 

I  —  I  Input 

I  —  I  In^t 

I  —  I  Input 

I  —  I  Liput 

I  —  I  Input 
I  —  I  Injwt 
I  —  I  Input 

I  —  I  Input 

-  I  —  I OND 

I  —  I  Input 

7  I  Normal  I  Output 
7  I  Normal  1 1A> 

7  INomtol  I  I/O 
7  (Normal  I  I/O 
7  (Normal  I  I/O 
7  (Normal  I  I/O 
7  (Normal  I  I/O 
7  I  Normal  I  Output 

-  I  —  (VCC 


end  of  module  palb 
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